16848: Adds an extra token to be displayed on the 'get token' dialog.
[arvados-workbench2.git] / src / store / auth / auth-reducer.ts
index a4195322c867316ce201f8d03ea4c28bffd25825..d55e8301df50713625a1cf13861018779661b0db 100644 (file)
 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;
+    extraApiToken?: string;
+    sshKeys: SshKeyResource[];
+    sessions: Session[];
+    localCluster: string;
+    homeCluster: string;
+    loginCluster: string;
+    remoteHosts: { [key: string]: string };
+    remoteHostsConfig: { [key: string]: Config };
+    config: Config;
 }
 
-export const authReducer = (services: ServiceRepository) => (state: AuthState = {}, action: AuthAction) => {
+const initialState: AuthState = {
+    user: undefined,
+    apiToken: undefined,
+    extraApiToken: undefined,
+    sshKeys: [],
+    sessions: [],
+    localCluster: "",
+    homeCluster: "",
+    loginCluster: "",
+    remoteHosts: {},
+    remoteHostsConfig: {},
+    config: mockConfig({})
+};
+
+export const authReducer = (services: ServiceRepository) => (state = initialState, action: AuthAction) => {
     return authActions.match(action, {
-        SAVE_API_TOKEN: (token: string) => {
-            return {...state, apiToken: token};
+        SET_CONFIG: ({ config }) => {
+            return {
+                ...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 }) => {
+            return {
+                ...state,
+                remoteHostsConfig: { ...state.remoteHostsConfig, [config.uuidPrefix]: config },
+            };
         },
-        INIT: ({ user, token }) => {
-            return { user, apiToken: token };
+        SET_EXTRA_TOKEN: ({ extraToken }) => ({ ...state, extraApiToken: extraToken }),
+        INIT_USER: ({ user, token }) => {
+            return { ...state, user, apiToken: token, homeCluster: user.uuid.substr(0, 5) };
         },
         LOGIN: () => {
             return state;
         },
         LOGOUT: () => {
-            return {...state, apiToken: undefined};
+            return { ...state, apiToken: undefined };
         },
         USER_DETAILS_SUCCESS: (user: User) => {
-            return {...state, user};
+            return { ...state, user, homeCluster: user.uuid.substr(0, 5) };
+        },
+        SET_SSH_KEYS: (sshKeys: SshKeyResource[]) => {
+            return { ...state, sshKeys };
+        },
+        ADD_SSH_KEY: (sshKey: SshKeyResource) => {
+            return { ...state, sshKeys: state.sshKeys.concat(sshKey) };
+        },
+        REMOVE_SSH_KEY: (uuid: string) => {
+            return { ...state, sshKeys: state.sshKeys.filter((sshKey) => sshKey.uuid !== uuid) };
+        },
+        SET_HOME_CLUSTER: (homeCluster: string) => {
+            return { ...state, homeCluster };
+        },
+        SET_SESSIONS: (sessions: Session[]) => {
+            return { ...state, sessions };
+        },
+        ADD_SESSION: (session: Session) => {
+            return { ...state, sessions: state.sessions.concat(session) };
+        },
+        REMOVE_SESSION: (clusterId: string) => {
+            return {
+                ...state,
+                sessions: state.sessions.filter(
+                    session => session.clusterId !== clusterId
+                )
+            };
+        },
+        UPDATE_SESSION: (session: Session) => {
+            return {
+                ...state,
+                sessions: state.sessions.map(
+                    s => s.clusterId === session.clusterId ? session : s
+                )
+            };
         },
         default: () => state
     });