X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/c28f185b9bf6a46bf02efd4a06439d14f09d6b8b..e10e24d713e5c31cbc34efca458f5718eb6eb000:/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 8d27b5bb..79a6b7e1 100644 --- a/src/services/auth-service/auth-service.ts +++ b/src/services/auth-service/auth-service.ts @@ -2,12 +2,12 @@ // // SPDX-License-Identifier: AGPL-3.0 -import { User, UserPrefs, getUserDisplayName } 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"; -import { Session, SessionStatus } from "~/models/session"; -import { Config } from "~/common/config"; +import { ApiActions } from "services/api/api-actions"; +import uuid from "uuid/v4"; +import { Session, SessionStatus } from "models/session"; +import { Config } from "common/config"; import { uniqBy } from "lodash"; export const TARGET_URL = 'targetURL'; @@ -22,6 +22,8 @@ export const USER_IS_ACTIVE = 'isActive'; export const USER_USERNAME = 'username'; export const USER_PREFS = 'prefs'; export const HOME_CLUSTER = 'homeCluster'; +export const LOCAL_STORAGE = 'localStorage'; +export const SESSION_STORAGE = 'sessionStorage'; export interface UserDetailsResponse { email: string; @@ -33,6 +35,8 @@ export interface UserDetailsResponse { is_active: boolean; username: string; prefs: UserPrefs; + can_write: boolean; + can_manage: boolean; } export class AuthService { @@ -50,24 +54,37 @@ export class AuthService { return localStorage; } + public getStorageType() { + if (this.useSessionStorage) { + return SESSION_STORAGE; + } + return LOCAL_STORAGE; + } + public saveApiToken(token: string) { + this.removeApiToken(); this.getStorage().setItem(API_TOKEN_KEY, token); const sp = token.split('/'); if (sp.length === 3) { - this.getStorage().setItem(HOME_CLUSTER, sp[1].substr(0, 5)); + this.getStorage().setItem(HOME_CLUSTER, sp[1].substring(0, 5)); } } + public setTargetUrl(url: string) { + localStorage.setItem(TARGET_URL, url); + } + public removeTargetURL() { - this.getStorage().removeItem(TARGET_URL); + localStorage.removeItem(TARGET_URL); } public getTargetURL() { - return this.getStorage().getItem(TARGET_URL); + return localStorage.getItem(TARGET_URL); } public removeApiToken() { - this.getStorage().removeItem(API_TOKEN_KEY); + localStorage.removeItem(API_TOKEN_KEY); + sessionStorage.removeItem(API_TOKEN_KEY); } public getApiToken() { @@ -83,29 +100,35 @@ export class AuthService { } public removeUser() { - 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); - this.getStorage().removeItem(TARGET_URL); + [localStorage, sessionStorage].forEach((storage) => { + storage.removeItem(USER_EMAIL_KEY); + storage.removeItem(USER_FIRST_NAME_KEY); + storage.removeItem(USER_LAST_NAME_KEY); + storage.removeItem(USER_UUID_KEY); + storage.removeItem(USER_OWNER_UUID_KEY); + storage.removeItem(USER_IS_ADMIN); + storage.removeItem(USER_IS_ACTIVE); + storage.removeItem(USER_USERNAME); + storage.removeItem(USER_PREFS); + storage.removeItem(TARGET_URL); + }); } public login(uuidPrefix: string, homeCluster: string, loginCluster: string, remoteHosts: { [key: string]: string }) { const currentUrl = `${window.location.protocol}//${window.location.host}/token`; const homeClusterHost = remoteHosts[homeCluster]; const rd = new URL(window.location.href); - this.getStorage().setItem(TARGET_URL, rd.pathname + rd.search); + this.setTargetUrl(rd.pathname + rd.search); window.location.assign(`https://${homeClusterHost}/login?${(uuidPrefix !== homeCluster && homeCluster !== loginCluster) ? "remote=" + uuidPrefix + "&" : ""}return_to=${currentUrl}`); } - public logout() { - const currentUrl = `${window.location.protocol}//${window.location.host}`; - window.location.assign(`${this.baseUrl || ""}/logout?return_to=${currentUrl}`); + public logout(expireToken: string, preservePath: boolean) { + const fullUrl = new URL(window.location.href); + const wbBase = `${fullUrl.protocol}//${fullUrl.host}`; + const wbPath = fullUrl.pathname + fullUrl.search; + const returnTo = `${wbBase}${preservePath ? wbPath : ''}` + + window.location.assign(`${this.baseUrl || ""}/logout?api_token=${expireToken}&return_to=${returnTo}`); } public getUserDetails = (showErrors?: boolean): Promise => { @@ -125,6 +148,8 @@ export class AuthService { isAdmin: resp.data.is_admin, isActive: resp.data.is_active, username: resp.data.username, + canWrite: resp.data.can_write, + canManage: resp.data.can_manage, prefs }; }) @@ -145,11 +170,13 @@ export class AuthService { } public saveSessions(sessions: Session[]) { + this.removeSessions(); this.getStorage().setItem("sessions", JSON.stringify(sessions)); } public removeSessions() { - this.getStorage().removeItem("sessions"); + localStorage.removeItem("sessions"); + sessionStorage.removeItem("sessions"); } public buildSessions(cfg: Config, user?: User) {