X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/e69ce2f8f14e4272acf5efa4c8a252bc101227ca..1d4e548cf6c8f11d939712ea5f4df06786a89d64:/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 c6e93a8f..75101711 100644 --- a/src/services/auth-service/auth-service.ts +++ b/src/services/auth-service/auth-service.ts @@ -2,7 +2,7 @@ // // SPDX-License-Identifier: AGPL-3.0 -import { getUserFullname, User, UserPrefs } from '~/models/user'; +import { User, UserPrefs, getUserDisplayName } from '~/models/user'; import { AxiosInstance } from "axios"; import { ApiActions } from "~/services/api/api-actions"; import * as uuid from "uuid/v4"; @@ -39,38 +39,50 @@ export class AuthService { constructor( protected apiClient: AxiosInstance, protected baseUrl: string, - protected actions: ApiActions) { } + protected actions: ApiActions, + protected useSessionStorage: boolean = false) { } + + private getStorage() { + if (this.useSessionStorage) { + return sessionStorage; + } + return localStorage; + } public saveApiToken(token: string) { - localStorage.setItem(API_TOKEN_KEY, token); + this.getStorage().setItem(API_TOKEN_KEY, token); const sp = token.split('/'); if (sp.length === 3) { - localStorage.setItem(HOME_CLUSTER, sp[1].substr(0, 5)); + this.getStorage().setItem(HOME_CLUSTER, sp[1].substr(0, 5)); } } public removeApiToken() { - localStorage.removeItem(API_TOKEN_KEY); + this.getStorage().removeItem(API_TOKEN_KEY); } public getApiToken() { - return localStorage.getItem(API_TOKEN_KEY) || undefined; + return this.getStorage().getItem(API_TOKEN_KEY) || undefined; } public getHomeCluster() { - return localStorage.getItem(HOME_CLUSTER) || undefined; + return this.getStorage().getItem(HOME_CLUSTER) || undefined; + } + + public getApiClient() { + return this.apiClient; } 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); - localStorage.removeItem(USER_IS_ADMIN); - localStorage.removeItem(USER_IS_ACTIVE); - localStorage.removeItem(USER_USERNAME); - localStorage.removeItem(USER_PREFS); + this.getStorage().removeItem(USER_EMAIL_KEY); + this.getStorage().removeItem(USER_FIRST_NAME_KEY); + this.getStorage().removeItem(USER_LAST_NAME_KEY); + this.getStorage().removeItem(USER_UUID_KEY); + this.getStorage().removeItem(USER_OWNER_UUID_KEY); + this.getStorage().removeItem(USER_IS_ADMIN); + this.getStorage().removeItem(USER_IS_ACTIVE); + this.getStorage().removeItem(USER_USERNAME); + this.getStorage().removeItem(USER_PREFS); } public login(uuidPrefix: string, homeCluster: string, loginCluster: string, remoteHosts: { [key: string]: string }) { @@ -84,7 +96,7 @@ export class AuthService { window.location.assign(`${this.baseUrl || ""}/logout?return_to=${currentUrl}`); } - public getUserDetails = (): Promise => { + public getUserDetails = (showErrors?: boolean): Promise => { const reqId = uuid(); this.actions.progressFn(reqId, true); return this.apiClient @@ -106,14 +118,14 @@ export class AuthService { }) .catch(e => { this.actions.progressFn(reqId, false); - this.actions.errorFn(reqId, e); + this.actions.errorFn(reqId, e, showErrors); throw e; }); } public getSessions(): Session[] { try { - const sessions = JSON.parse(localStorage.getItem("sessions") || ''); + const sessions = JSON.parse(this.getStorage().getItem("sessions") || ''); return sessions; } catch { return []; @@ -121,7 +133,11 @@ export class AuthService { } public saveSessions(sessions: Session[]) { - localStorage.setItem("sessions", JSON.stringify(sessions)); + this.getStorage().setItem("sessions", JSON.stringify(sessions)); + } + + public removeSessions() { + this.getStorage().removeItem("sessions"); } public buildSessions(cfg: Config, user?: User) { @@ -129,13 +145,15 @@ export class AuthService { clusterId: cfg.uuidPrefix, remoteHost: cfg.rootUrl, baseUrl: cfg.baseUrl, - name: getUserFullname(user), + name: user ? getUserDisplayName(user) : '', email: user ? user.email : '', + userIsActive: user ? user.isActive : false, token: this.getApiToken(), loggedIn: true, active: true, uuid: user ? user.uuid : '', - status: SessionStatus.VALIDATED + status: SessionStatus.VALIDATED, + apiRevision: cfg.apiRevision, } as Session; const localSessions = this.getSessions().map(s => ({ ...s, @@ -155,7 +173,8 @@ export class AuthService { loggedIn: false, active: false, uuid: '', - status: SessionStatus.INVALIDATED + status: SessionStatus.INVALIDATED, + apiRevision: 0, } as Session; }); const sessions = [currentSession]