EN · DE · RU · FR · ES

#2467: authentication.js

projectforge-webapp/src/actions/authentication.js Tipo: JavaScript/React · Rol: Componente · Fuente: projectforge-webapp/src/actions/authentication.js 85 líneas · 73 código · 3 comentarios · 9 en blanco
Módulo de autenticación de React que maneja el estado de inicio de sesión, la gestión de tokens y la persistencia de la sesión.

Estructura del código

Componentes: USER_LOGIN_BEGIN, USER_LOGIN_SUCCESS, USER_LOGIN_FAILURE

Hooks utilizados: rLoginFailure, rLoginBegin, rLoginSuccess, rLoginBegin

Exportaciones: USER_LOGIN_BEGIN, USER_LOGIN_SUCCESS, USER_LOGIN_FAILURE, userLoginBegin, userLoginSuccess, userLoginFailure, loadUserStatus, login

Importaciones de: ../utilities/rest

Código fuente (resumido)

import { getServiceURL, handleHTTPErrors } from '../utilities/rest';

export const USER_LOGIN_BEGIN = 'USER_LOGIN_BEGIN';
export const USER_LOGIN_SUCCESS = 'USER_LOGIN_SUCCESS';
export const USER_LOGIN_FAILURE = 'USER_LOGIN_FAILURE';

export const userLoginBegin = () => ({
    type: USER_LOGIN_BEGIN,
});

export const userLoginSuccess = (user, version, buildTimestamp, alertMessage) => ({
    type: USER_LOGIN_SUCCESS,
    payload: {
        user,
        version,
        buildTimestamp,
        alertMessage,
    },
});

export const userLoginFailure = (error) => ({
    type: USER_LOGIN_FAILURE,
    payload: {
        error,
    },
});

const catchError = (dispatch) => (error) => dispatch(userLoginFailure(error.message));

export const loadUserStatus = () => (dispatch) => {
    dispatch(userLoginBegin());

    return fetch(
        getServiceURL('userStatus'),
        {
            method: 'GET',
            credentials: 'include',
        },
    )
        .then(handleHTTPErrors)
        .then((response) => response.json())
        .then(({ userData, systemData, alertMessage }) => {
            dispatch(userLoginSuccess(
                userData,
                systemData.version,
                systemData.buildTimestamp,
                alertMessage,
            ));
        })
        .catch(() => {
            const { pathname, search } = window.location;
            const href = pathname + search;
            if (!pathname.startsWith('/react/public/login')
                // /react/public/datatransfer/ es un caso especial donde el usuario no ha iniciado sesión.
                // El formulario de inicio de sesión es devuelto por la transferencia de datos.
                && !pathname.startsWith('/react/public/datatransfer/')) {
                // establecer la URL para redirigir después del inicio de sesión:
                window.location.href = `/react/public/login?url=${encodeURIComponent(href)}`;
            }

            catchError(dispatch)({ message: undefined });
        });
};

export const login = (username, password, keepSignedIn) => (dispatch) => {
    dispatch(userLoginBegin());
    return fetch(
        getServiceURL('/rsPublic/login'),
        {
            method: 'POST',
            headers: {
                'Content-Type': 'application/json',
            },
            body: JSON.stringify({
                username,
                password,
                stayLoggedIn: keepSignedIn,
            }),
            credentials: 'include',
        },
    )
        .then(handleHTTPErrors)
        .then(() => loadUserStatus()(dispatch))
        .catch(catchError(dispatch));
};

Historial de Git

e2061d7db UserPrefDao: Suprimir registro de error en TimesheetPrefData antiguo. Manejo de inicio de sesión mejorado: redirigir a la URL de origen después del inicio de sesión.
cc0eb7b56 DataTransferPublicPagesRest: no mostrar token de acceso en el formulario de inicio de sesión. Inicio de sesión corregido.
7c88abd0f wip dependencias de elevación
bbd81edc3 es-lint, nuevas versiones de js.
4f5a06d6f AppVersion eliminado. Información de Git añadida a ProjectForgeVersion.