bruno/renderer/providers/Auth/index.js

64 lines
1.4 KiB
JavaScript
Raw Permalink Normal View History

2022-03-07 15:32:39 +01:00
import React, { useEffect, useReducer } from 'react';
import { useRouter } from 'next/router';
2022-03-07 21:52:21 +01:00
import AuthApi from 'api/auth';
2022-03-07 15:32:39 +01:00
import reducer from './reducer';
const AuthContext = React.createContext();
const initialState = {
isLoading: true,
lastStateTransition: null,
currentUser: null
};
export const AuthProvider = props => {
const router = useRouter();
const [state, dispatch] = useReducer(reducer, initialState);
useEffect(() => {
2022-03-07 21:52:21 +01:00
AuthApi
2022-03-07 15:32:39 +01:00
.whoami()
.then((response) => {
let data = response.data;
dispatch({
type: 'WHOAMI_SUCCESS',
user : {
id: data.id,
name: data.name,
username: data.username
}
});
})
.catch((error) => {
dispatch({
type: 'WHOAMI_ERROR',
error: error
});
});
}, []);
useEffect(() => {
if(state.lastStateTransition === 'LOGIN_SUCCESS') {
2022-03-07 21:52:21 +01:00
router.push('/');
2022-03-07 15:32:39 +01:00
}
if(state.lastStateTransition === 'WHOAMI_ERROR') {
// Todo: decide action
// router.push('/login');
}
}, [state]);
return <AuthContext.Provider value={[state, dispatch]} {...props} />;
};
export const useAuth = () => {
const context = React.useContext(AuthContext);
if (context === undefined) {
throw new Error(`useAuth must be used within a AuthProvider`);
}
return context;
};
export default AuthProvider;