feat: retrieve user and token data from storage

This commit is contained in:
Vinicius Souza 2024-11-01 10:41:28 -03:00
parent bc8d95a912
commit 17919bad60
2 changed files with 19 additions and 10 deletions

View file

@ -3,7 +3,7 @@ import { createContext, useEffect, useState } from 'react';
import { UserDTO } from '@dtos/UserDTO';
import { api } from '@services/api';
import { storageUserGet, storageUserRemove, storageUserSave } from '@storage/storageUser';
import { storageAuthTokenSave } from '@storage/storageAuthToken';
import { storageAuthTokenGet, storageAuthTokenSave } from '@storage/storageAuthToken';
type AuthContextData = {
user: UserDTO;
@ -22,17 +22,17 @@ export function AuthContextProvider({ children }: AuthContextProviderProps) {
const [user, setUser] = useState<UserDTO>({} as UserDTO);
const [isLoadingUserStorageData, setIsLoadingUserStorageData] = useState(true);
async function storeUserAndToken(userData: UserDTO, token: string) {
async function updateUserAndTokenData(userData: UserDTO, token: string) {
api.defaults.headers.common['Authorization'] = `Bearer ${token}`;
setUser(userData);
}
async function saveUserAndTokenStorageData(userData: UserDTO, token: string) {
try {
setIsLoadingUserStorageData(true);
api.defaults.headers.common['Authorization'] = `Bearer ${token}`;
setUser(userData);
await storageUserSave(userData);
await storageAuthTokenSave(token);
} catch (error) {
console.error(error);
throw error;
} finally {
setIsLoadingUserStorageData(false);
@ -44,7 +44,8 @@ export function AuthContextProvider({ children }: AuthContextProviderProps) {
const { data } = await api.post('/sessions', { email, password });
if (data.user && data.token) {
storeUserAndToken(data.user, data.token);
saveUserAndTokenStorageData(data.user, data.token);
updateUserAndTokenData(data.user, data.token);
}
} catch (error) {
console.error(error);
@ -67,9 +68,13 @@ export function AuthContextProvider({ children }: AuthContextProviderProps) {
async function loadUserData() {
try {
setIsLoadingUserStorageData(true);
const loggedUser = await storageUserGet();
if (loggedUser) {
setUser(loggedUser);
const token = await storageAuthTokenGet();
if (loggedUser && token) {
updateUserAndTokenData(loggedUser, token);
}
} catch (error) {
throw error;

View file

@ -5,3 +5,7 @@ import { TOKEN_STORAGE } from './storageConfig';
export async function storageAuthTokenSave(token: string) {
await AsyncStorage.setItem(TOKEN_STORAGE, token);
}
export async function storageAuthTokenGet() {
return await AsyncStorage.getItem(TOKEN_STORAGE);
}