X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/a8223b83cc9ae48174718d124a38a504d5312651..ecfd85a34f5852c160a25ab61bc5c38059927c56:/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 da96f1629b..61db625c62 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, UserResource } 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"; @@ -43,7 +43,10 @@ export class AuthService { public saveApiToken(token: string) { localStorage.setItem(API_TOKEN_KEY, token); - localStorage.setItem(HOME_CLUSTER, token.split('/')[1].substr(0, 5)); + const sp = token.split('/'); + if (sp.length === 3) { + localStorage.setItem(HOME_CLUSTER, sp[1].substr(0, 5)); + } } public removeApiToken() { @@ -58,50 +61,6 @@ export class AuthService { return localStorage.getItem(HOME_CLUSTER) || undefined; } - public getUuid() { - return localStorage.getItem(USER_UUID_KEY) || undefined; - } - - public getOwnerUuid() { - return localStorage.getItem(USER_OWNER_UUID_KEY) || undefined; - } - - public getIsAdmin(): boolean { - return localStorage.getItem(USER_IS_ADMIN) === 'true'; - } - - public getIsActive(): boolean { - return localStorage.getItem(USER_IS_ACTIVE) === 'true'; - } - - 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 = this.getUuid(); - const ownerUuid = this.getOwnerUuid(); - const isAdmin = this.getIsAdmin(); - const isActive = this.getIsActive(); - const username = localStorage.getItem(USER_USERNAME); - const prefs = JSON.parse(localStorage.getItem(USER_PREFS) || '{"profile": {}}'); - - return email && firstName && lastName && uuid && ownerUuid && username && prefs - ? { email, firstName, lastName, uuid, ownerUuid, isAdmin, isActive, username, prefs } - : undefined; - } - - public saveUser(user: User | UserResource) { - 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); - localStorage.setItem(USER_IS_ADMIN, JSON.stringify(user.isAdmin)); - localStorage.setItem(USER_IS_ACTIVE, JSON.stringify(user.isActive)); - localStorage.setItem(USER_USERNAME, user.username); - localStorage.setItem(USER_PREFS, JSON.stringify(user.prefs)); - } - public removeUser() { localStorage.removeItem(USER_EMAIL_KEY); localStorage.removeItem(USER_FIRST_NAME_KEY); @@ -152,12 +111,6 @@ export class AuthService { }); } - public getRootUuid() { - const uuid = this.getOwnerUuid(); - const uuidParts = uuid ? uuid.split('-') : []; - return uuidParts.length > 1 ? `${uuidParts[0]}-${uuidParts[1]}` : undefined; - } - public getSessions(): Session[] { try { const sessions = JSON.parse(localStorage.getItem("sessions") || ''); @@ -176,12 +129,14 @@ export class AuthService { clusterId: cfg.uuidPrefix, remoteHost: cfg.rootUrl, baseUrl: cfg.baseUrl, - username: getUserFullname(user), + name: user ? getUserDisplayName(user): '', email: user ? user.email : '', token: this.getApiToken(), loggedIn: true, active: true, - status: SessionStatus.VALIDATED + uuid: user ? user.uuid : '', + status: SessionStatus.VALIDATED, + apiRevision: cfg.apiRevision, } as Session; const localSessions = this.getSessions().map(s => ({ ...s, @@ -195,12 +150,14 @@ export class AuthService { clusterId, remoteHost, baseUrl: '', - username: '', + name: '', email: '', token: '', loggedIn: false, active: false, - status: SessionStatus.INVALIDATED + uuid: '', + status: SessionStatus.INVALIDATED, + apiRevision: 0, } as Session; }); const sessions = [currentSession]