X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/16b7bebe83b28b5622f23385df5cacbd66bc425b..25691034b44b9323cae96c8db002826880ccfd7e:/src/store/auth/auth-reducer.ts diff --git a/src/store/auth/auth-reducer.ts b/src/store/auth/auth-reducer.ts index 730312f7ce..a4195322c8 100644 --- a/src/store/auth/auth-reducer.ts +++ b/src/store/auth/auth-reducer.ts @@ -2,50 +2,32 @@ // // SPDX-License-Identifier: AGPL-3.0 -import actions, { AuthAction, UserDetailsResponse } from "./auth-action"; -import { User } from "../../models/user"; -import { authService } from "../../services/services"; -import { removeServerApiAuthorizationHeader, setServerApiAuthorizationHeader } from "../../common/server-api"; +import { authActions, AuthAction } from "./auth-action"; +import { User } from "~/models/user"; +import { ServiceRepository } from "~/services/services"; export interface AuthState { user?: User; apiToken?: string; -}; +} -const authReducer = (state: AuthState = {}, action: AuthAction) => { - return actions.match(action, { +export const authReducer = (services: ServiceRepository) => (state: AuthState = {}, action: AuthAction) => { + return authActions.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(); + INIT: ({ user, 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 - }; - authService.saveUser(user); + USER_DETAILS_SUCCESS: (user: User) => { return {...state, user}; }, default: () => state }); }; - -export default authReducer;