//
// 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;