X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/7adbd161925c71840bf4ddb799b87f1734e5af7e..HEAD:/src/store/auth/auth-reducer.ts diff --git a/src/store/auth/auth-reducer.ts b/src/store/auth/auth-reducer.ts index 02b9d30c..c109acaf 100644 --- a/src/store/auth/auth-reducer.ts +++ b/src/store/auth/auth-reducer.ts @@ -2,56 +2,112 @@ // // SPDX-License-Identifier: AGPL-3.0 -import actions, { AuthAction } from "./auth-action"; -import { User } from "../../models/user"; -import { authService } from "../../services/services"; -import { removeServerApiAuthorizationHeader, setServerApiAuthorizationHeader } from "../../common/api/server-api"; -import { UserDetailsResponse } from "../../services/auth-service/auth-service"; +import { authActions, AuthAction } from "./auth-action"; +import { User } from "models/user"; +import { ServiceRepository } from "services/services"; +import { SshKeyResource } from 'models/ssh-key'; +import { Session } from "models/session"; +import { Config, mockConfig } from 'common/config'; export interface AuthState { user?: User; apiToken?: string; + apiTokenExpiration?: Date; + apiTokenLocation?: string; + extraApiToken?: string; + extraApiTokenExpiration?: Date; + sshKeys: SshKeyResource[]; + sessions: Session[]; + localCluster: string; + homeCluster: string; + loginCluster: string; + remoteHosts: { [key: string]: string }; + remoteHostsConfig: { [key: string]: Config }; + config: Config; } -const authReducer = (state: AuthState = {}, action: AuthAction) => { - return actions.match(action, { - SAVE_API_TOKEN: (token: string) => { - authService.saveApiToken(token); - setServerApiAuthorizationHeader(token); - return {...state, apiToken: token}; - }, - INIT: () => { - const user = authService.getUser(); - const token = authService.getApiToken(); - if (token) { - setServerApiAuthorizationHeader(token); - } - return {user, apiToken: token}; - }, - LOGIN: () => { - authService.login(); - return state; - }, - LOGOUT: () => { - authService.removeApiToken(); - authService.removeUser(); - removeServerApiAuthorizationHeader(); - authService.logout(); - return {...state, apiToken: undefined}; - }, - USER_DETAILS_SUCCESS: (ud: UserDetailsResponse) => { - const user = { - email: ud.email, - firstName: ud.first_name, - lastName: ud.last_name, - uuid: ud.uuid, - ownerUuid: ud.owner_uuid - }; - authService.saveUser(user); - return {...state, user}; - }, +const initialState: AuthState = { + user: undefined, + apiToken: undefined, + apiTokenExpiration: undefined, + apiTokenLocation: undefined, + extraApiToken: undefined, + extraApiTokenExpiration: undefined, + sshKeys: [], + sessions: [], + localCluster: "", + homeCluster: "", + loginCluster: "", + remoteHosts: {}, + remoteHostsConfig: {}, + config: mockConfig({}) +}; + +export const authReducer = (services: ServiceRepository) => (state = initialState, action: AuthAction) => { + return authActions.match(action, { + SET_CONFIG: ({ config }) => + ({ + ...state, + config, + localCluster: config.uuidPrefix, + remoteHosts: { + ...config.remoteHosts, + [config.uuidPrefix]: new URL(config.rootUrl).host + }, + homeCluster: config.loginCluster || config.uuidPrefix, + loginCluster: config.loginCluster, + remoteHostsConfig: { + ...state.remoteHostsConfig, + [config.uuidPrefix]: config + } + }), + REMOTE_CLUSTER_CONFIG: ({ config }) => + ({ + ...state, + remoteHostsConfig: { + ...state.remoteHostsConfig, + [config.uuidPrefix]: config + }, + }), + SET_EXTRA_TOKEN: ({ extraApiToken, extraApiTokenExpiration }) => + ({ ...state, extraApiToken, extraApiTokenExpiration }), + RESET_EXTRA_TOKEN: () => + ({ ...state, extraApiToken: undefined, extraApiTokenExpiration: undefined }), + INIT_USER: ({ user, token, tokenExpiration, tokenLocation = state.apiTokenLocation }) => + ({ ...state, + user, + apiToken: token, + apiTokenExpiration: tokenExpiration, + apiTokenLocation: tokenLocation, + homeCluster: user.uuid.substring(0, 5) + }), + LOGIN: () => state, + LOGOUT: () => ({ ...state, apiToken: undefined }), + USER_DETAILS_SUCCESS: (user: User) => + ({ ...state, user, homeCluster: user.uuid.substring(0, 5) }), + SET_SSH_KEYS: (sshKeys: SshKeyResource[]) => ({ ...state, sshKeys }), + ADD_SSH_KEY: (sshKey: SshKeyResource) => + ({ ...state, sshKeys: state.sshKeys.concat(sshKey) }), + REMOVE_SSH_KEY: (uuid: string) => + ({ ...state, sshKeys: state.sshKeys.filter((sshKey) => sshKey.uuid !== uuid) }), + SET_HOME_CLUSTER: (homeCluster: string) => ({ ...state, homeCluster }), + SET_SESSIONS: (sessions: Session[]) => ({ ...state, sessions }), + ADD_SESSION: (session: Session) => + ({ ...state, sessions: state.sessions.concat(session) }), + REMOVE_SESSION: (clusterId: string) => + ({ + ...state, + sessions: state.sessions.filter( + session => session.clusterId !== clusterId + ) + }), + UPDATE_SESSION: (session: Session) => + ({ + ...state, + sessions: state.sessions.map( + s => s.clusterId === session.clusterId ? session : s + ) + }), default: () => state }); }; - -export default authReducer;