Introduce service repository
[arvados-workbench2.git] / src / store / auth / auth-reducer.ts
index 366385d50b506de529139f3f75151762f6a6285a..e3f968a8d4bbe91f781a080c231a3cea8180d2d2 100644 (file)
@@ -4,7 +4,7 @@
 
 import { authActions, AuthAction } from "./auth-action";
 import { User } from "../../models/user";
-import { authService } from "../../services/services";
+import { ServiceRepository } from "../../services/services";
 import { removeServerApiAuthorizationHeader, setServerApiAuthorizationHeader } from "../../common/api/server-api";
 
 export interface AuthState {
@@ -12,34 +12,34 @@ export interface AuthState {
     apiToken?: string;
 }
 
-export const authReducer = (state: AuthState = {}, action: AuthAction) => {
+export const authReducer = (services: ServiceRepository) => (state: AuthState = {}, action: AuthAction) => {
     return authActions.match(action, {
         SAVE_API_TOKEN: (token: string) => {
-            authService.saveApiToken(token);
+            services.authService.saveApiToken(token);
             setServerApiAuthorizationHeader(token);
             return {...state, apiToken: token};
         },
         INIT: () => {
-            const user = authService.getUser();
-            const token = authService.getApiToken();
+            const user = services.authService.getUser();
+            const token = services.authService.getApiToken();
             if (token) {
                 setServerApiAuthorizationHeader(token);
             }
             return {user, apiToken: token};
         },
         LOGIN: () => {
-            authService.login();
+            services.authService.login();
             return state;
         },
         LOGOUT: () => {
-            authService.removeApiToken();
-            authService.removeUser();
+            services.authService.removeApiToken();
+            services.authService.removeUser();
             removeServerApiAuthorizationHeader();
-            authService.logout();
+            services.authService.logout();
             return {...state, apiToken: undefined};
         },
         USER_DETAILS_SUCCESS: (user: User) => {
-            authService.saveUser(user);
+            services.authService.saveUser(user);
             return {...state, user};
         },
         default: () => state