421ecf17e6
* Reorganize repo * Overhaul website design and rewrite in NextJS and Typescript * Delete website-publish.yml
99 lines
2.8 KiB
TypeScript
99 lines
2.8 KiB
TypeScript
import { currentBackend } from '../backend';
|
|
import { addSnackbar, removeSnackbarById } from '../store/slices/snackbars';
|
|
|
|
import type { AnyAction } from 'redux';
|
|
import type { ThunkDispatch } from 'redux-thunk';
|
|
import type { RootState } from '../store';
|
|
|
|
export const STATUS_REQUEST = 'STATUS_REQUEST';
|
|
export const STATUS_SUCCESS = 'STATUS_SUCCESS';
|
|
export const STATUS_FAILURE = 'STATUS_FAILURE';
|
|
|
|
export function statusRequest() {
|
|
return {
|
|
type: STATUS_REQUEST,
|
|
} as const;
|
|
}
|
|
|
|
export function statusSuccess(status: {
|
|
auth: { status: boolean };
|
|
api: { status: boolean; statusPage: string };
|
|
}) {
|
|
return {
|
|
type: STATUS_SUCCESS,
|
|
payload: { status },
|
|
} as const;
|
|
}
|
|
|
|
export function statusFailure(error: Error) {
|
|
return {
|
|
type: STATUS_FAILURE,
|
|
payload: { error },
|
|
} as const;
|
|
}
|
|
|
|
export function checkBackendStatus() {
|
|
return async (dispatch: ThunkDispatch<RootState, {}, AnyAction>, getState: () => RootState) => {
|
|
try {
|
|
const state = getState();
|
|
const config = state.config.config;
|
|
if (state.status.isFetching || !config) {
|
|
return;
|
|
}
|
|
|
|
dispatch(statusRequest());
|
|
const backend = currentBackend(config);
|
|
const status = await backend.status();
|
|
|
|
const backendDownKey = 'ui.toast.onBackendDown';
|
|
const previousBackendDownNotifs = state.snackbar.messages.filter(
|
|
n => typeof n.message !== 'string' && n.message.key === backendDownKey,
|
|
);
|
|
|
|
if (status.api.status === false) {
|
|
if (previousBackendDownNotifs.length === 0) {
|
|
dispatch(
|
|
addSnackbar({
|
|
type: 'error',
|
|
message: { key: 'ui.toast.onBackendDown', details: status.api.statusPage },
|
|
}),
|
|
);
|
|
}
|
|
return dispatch(statusSuccess(status));
|
|
} else if (status.api.status === true && previousBackendDownNotifs.length > 0) {
|
|
// If backend is up, clear all the danger messages
|
|
previousBackendDownNotifs.forEach(notif => {
|
|
dispatch(removeSnackbarById(notif.id));
|
|
});
|
|
}
|
|
|
|
const authError = status.auth.status === false;
|
|
if (authError) {
|
|
const key = 'ui.toast.onLoggedOut';
|
|
const existingNotification = state.snackbar.messages.find(
|
|
n => typeof n.message !== 'string' && n.message.key === key,
|
|
);
|
|
if (!existingNotification) {
|
|
dispatch(
|
|
addSnackbar({
|
|
type: 'error',
|
|
message: { key: 'ui.toast.onLoggedOut' },
|
|
}),
|
|
);
|
|
}
|
|
}
|
|
|
|
dispatch(statusSuccess(status));
|
|
} catch (error: unknown) {
|
|
console.error(error);
|
|
if (error instanceof Error) {
|
|
dispatch(statusFailure(error));
|
|
}
|
|
}
|
|
};
|
|
}
|
|
|
|
export type StatusAction = ReturnType<
|
|
typeof statusRequest | typeof statusSuccess | typeof statusFailure
|
|
>;
|