X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/dcebdbfbd2d54d580932681a7ce182d27d0f98d8..c77b1a5becebf382fddc349ae9081503d511a02a:/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 80d13e3c64..07e0ff0913 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 { API_HOST, serverApi } from "../../common/server-api"; +import { API_HOST, serverApi } from "../../common/api/server-api"; import { User } from "../../models/user"; import { Dispatch } from "redux"; import actions from "../../store/auth/auth-action"; @@ -11,11 +11,15 @@ 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 interface UserDetailsResponse { email: string; first_name: string; last_name: string; + uuid: string; + owner_uuid: string; is_admin: boolean; } @@ -33,12 +37,19 @@ export default class AuthService { return localStorage.getItem(API_TOKEN_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); - return email && firstName && lastName - ? { email, firstName, lastName } + 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; } @@ -46,12 +57,16 @@ export default class AuthService { 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 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() { @@ -64,14 +79,18 @@ export default class AuthService { window.location.assign(`${API_HOST}/logout?return_to=${currentUrl}`); } - public getUserDetails = () => (dispatch: Dispatch) => { + public getUserDetails = () => (dispatch: Dispatch): Promise => { dispatch(actions.USER_DETAILS_REQUEST()); - serverApi + return serverApi .get('/users/current') .then(resp => { dispatch(actions.USER_DETAILS_SUCCESS(resp.data)); - }) - // .catch(err => { - // }); + }); }; + + public getRootUuid() { + const uuid = this.getOwnerUuid(); + const uuidParts = uuid ? uuid.split('-') : []; + return uuidParts.length > 1 ? `${uuidParts[0]}-${uuidParts[1]}` : undefined; + } }