X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/6f8e509988756deb7e05a760e718d1ade164fd19..92dd5d32b573b5c90f3ce72dc207f6d0e7f21178:/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 89545c1f..d4e81e42 100644 --- a/src/services/auth-service/auth-service.ts +++ b/src/services/auth-service/auth-service.ts @@ -2,9 +2,9 @@ // // SPDX-License-Identifier: AGPL-3.0 -import { User } from "~/models/user"; +import { User, userPrefs } from "~/models/user"; import { AxiosInstance } from "axios"; -import { ProgressFn } from "~/services/api/api-progress"; +import { ApiActions, ProgressFn } from "~/services/api/api-actions"; import * as uuid from "uuid/v4"; export const API_TOKEN_KEY = 'apiToken'; @@ -13,6 +13,8 @@ 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_IDENTITY_URL = 'identityUrl'; +export const USER_PREFS = 'prefs'; export interface UserDetailsResponse { email: string; @@ -21,6 +23,8 @@ export interface UserDetailsResponse { uuid: string; owner_uuid: string; is_admin: boolean; + identity_url: string; + prefs: userPrefs; } export class AuthService { @@ -28,7 +32,7 @@ export class AuthService { constructor( protected apiClient: AxiosInstance, protected baseUrl: string, - protected progressFn: ProgressFn) { } + protected actions: ApiActions) { } public saveApiToken(token: string) { localStorage.setItem(API_TOKEN_KEY, token); @@ -56,9 +60,10 @@ export class AuthService { const lastName = localStorage.getItem(USER_LAST_NAME_KEY); 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 } + const identityUrl = localStorage.getItem(USER_IDENTITY_URL); + const prefs = JSON.parse(localStorage.getItem(USER_PREFS) || '{"profile": {}}'); + return email && firstName && lastName && uuid && ownerUuid && identityUrl && prefs + ? { email, firstName, lastName, uuid, ownerUuid, identityUrl, prefs } : undefined; } @@ -68,6 +73,8 @@ 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_IDENTITY_URL, user.identityUrl); + localStorage.setItem(USER_PREFS, JSON.stringify(user.prefs)); } public removeUser() { @@ -76,6 +83,8 @@ export class AuthService { localStorage.removeItem(USER_LAST_NAME_KEY); localStorage.removeItem(USER_UUID_KEY); localStorage.removeItem(USER_OWNER_UUID_KEY); + localStorage.removeItem(USER_IDENTITY_URL); + localStorage.removeItem(USER_PREFS); } public login() { @@ -90,21 +99,26 @@ export class AuthService { public getUserDetails = (): Promise => { const reqId = uuid(); - this.progressFn(reqId, true); + this.actions.progressFn(reqId, true); return this.apiClient .get('/users/current') .then(resp => { - this.progressFn(reqId, false); + this.actions.progressFn(reqId, false); + const prefs = resp.data.prefs.profile ? resp.data.prefs : { profile: {}}; + console.log(resp.data); return { email: resp.data.email, firstName: resp.data.first_name, lastName: resp.data.last_name, uuid: resp.data.uuid, - ownerUuid: resp.data.owner_uuid + ownerUuid: resp.data.owner_uuid, + identityUrl: resp.data.identity_url, + prefs }; }) .catch(e => { - this.progressFn(reqId, false); + this.actions.progressFn(reqId, false); + this.actions.errorFn(reqId, e); throw e; }); }