salix-front/src/composables/useSession.js

133 lines
3.9 KiB
JavaScript
Raw Normal View History

2022-03-24 15:49:33 +00:00
import { useState } from './useState';
import { useRole } from './useRole';
import { useUserConfig } from './useUserConfig';
import axios from 'axios';
import useNotify from './useNotify';
2024-04-19 10:26:43 +00:00
import { useTokenConfig } from './useTokenConfig';
const TOKEN_MULTIMEDIA = 'tokenMultimedia';
const TOKEN = 'token';
2022-03-24 15:49:33 +00:00
export function useSession() {
const { notify } = useNotify();
2024-04-19 10:26:43 +00:00
let isCheckingToken = false;
2022-03-24 15:49:33 +00:00
function getToken() {
const localToken = localStorage.getItem(TOKEN);
const sessionToken = sessionStorage.getItem(TOKEN);
2022-03-24 15:49:33 +00:00
return localToken || sessionToken || '';
}
function getTokenMultimedia() {
const localTokenMultimedia = localStorage.getItem(TOKEN_MULTIMEDIA);
const sessionTokenMultimedia = sessionStorage.getItem(TOKEN_MULTIMEDIA);
return localTokenMultimedia || sessionTokenMultimedia || '';
}
2022-03-24 15:49:33 +00:00
function setToken(data) {
2024-04-19 10:26:43 +00:00
let keepLogin = data.keepLogin ?? sessionStorage.getItem('keepLogin');
if (!keepLogin) keepLogin = false;
const storage = keepLogin ? localStorage : sessionStorage;
storage.setItem(TOKEN, data.token);
storage.setItem(TOKEN_MULTIMEDIA, data.tokenMultimedia);
2024-04-19 10:26:43 +00:00
sessionStorage.setItem('keepLogin', keepLogin);
2022-03-24 15:49:33 +00:00
}
async function destroyToken(url, storage, key) {
if (storage.getItem(key)) {
try {
await axios.post(url, null, {
headers: { Authorization: storage.getItem(key) },
});
} catch (error) {
2024-03-15 11:43:56 +00:00
notify('errors.statusUnauthorized', 'negative');
} finally {
storage.removeItem(key);
}
}
}
async function destroy() {
const tokens = {
tokenMultimedia: 'Accounts/logout',
token: 'VnUsers/logout',
};
for (const [key, url] of Object.entries(tokens)) {
await destroyToken(url, localStorage, key);
await destroyToken(url, sessionStorage, key);
}
2022-03-24 15:49:33 +00:00
const { setUser } = useState();
setUser({
id: 0,
name: '',
2022-03-24 15:49:33 +00:00
nickname: '',
lang: '',
darkMode: null,
2022-03-24 15:49:33 +00:00
});
2024-04-19 10:26:43 +00:00
stopRenewer();
2022-03-24 15:49:33 +00:00
}
async function login(token, tokenMultimedia, keepLogin) {
setToken({ token, tokenMultimedia, keepLogin });
await useRole().fetch();
await useUserConfig().fetch();
2024-04-19 10:26:43 +00:00
await useTokenConfig().fetch();
await checkValidity();
}
2022-03-24 15:49:33 +00:00
function isLoggedIn() {
const localToken = localStorage.getItem(TOKEN);
const sessionToken = sessionStorage.getItem(TOKEN);
2022-03-24 15:49:33 +00:00
return !!(localToken || sessionToken);
}
2024-04-19 10:26:43 +00:00
function stopRenewer() {
clearInterval(this.intervalId);
}
async function renewToken() {
const _token = getToken();
const token = await axios.post('VnUsers/renewToken', {
headers: { Authorization: _token },
});
const _tokenMultimedia = getTokenMultimedia();
const tokenMultimedia = await axios.post('VnUsers/renewToken', {
headers: { Authorization: _tokenMultimedia },
});
setToken({ token, tokenMultimedia });
}
async function checkValidity() {
const { getTokenConfig } = useState();
const tokenConfig = getTokenConfig();
const created = +localStorage.getItem('created');
const ttl = localStorage.getItem('ttl');
if (isCheckingToken || !created) return;
isCheckingToken = true;
const renewPeriodInSeconds = Math.min(ttl, tokenConfig.value.renewPeriod) * 1000;
const maxDate = created + renewPeriodInSeconds;
const now = new Date();
if (now.getTime() <= maxDate) return (isCheckingToken = false);
await renewToken();
isCheckingToken = false;
}
2022-03-24 15:49:33 +00:00
return {
getToken,
getTokenMultimedia,
2022-03-24 15:49:33 +00:00
setToken,
destroy,
login,
2022-03-24 15:49:33 +00:00
isLoggedIn,
};
}