gtsoft-snail-job-admin/src/store/modules/auth/index.ts

137 lines
3.5 KiB
TypeScript
Raw Normal View History

2024-03-08 17:59:45 +08:00
import { computed, reactive, ref } from 'vue';
2024-04-25 10:16:17 +08:00
import { useRoute } from 'vue-router';
2024-03-08 17:59:45 +08:00
import { defineStore } from 'pinia';
import { useLoading } from '@sa/hooks';
import { SetupStoreId } from '@/enum';
import { useRouterPush } from '@/hooks/common/router';
import { fetchGetUserInfo, fetchLogin } from '@/service/api';
import { localStg } from '@/utils/storage';
import { $t } from '@/locales';
2024-05-10 17:15:06 +08:00
import { roleTypeRecord } from '@/constants/business';
2024-03-08 17:59:45 +08:00
import { useRouteStore } from '../route';
import { clearAuthStorage, getToken, getUserInfo } from './shared';
export const useAuthStore = defineStore(SetupStoreId.Auth, () => {
2024-04-25 10:16:17 +08:00
const route = useRoute();
2024-03-08 17:59:45 +08:00
const routeStore = useRouteStore();
2024-04-25 10:16:17 +08:00
const { toLogin, redirectFromLogin } = useRouterPush(false);
2024-03-08 17:59:45 +08:00
const { loading: loginLoading, startLoading, endLoading } = useLoading();
const token = ref(getToken());
const userInfo: Api.Auth.UserInfo = reactive(getUserInfo());
2024-03-26 11:47:11 +08:00
/** is super role in static route */
const isStaticSuper = computed(() => {
const { VITE_AUTH_ROUTE_MODE, VITE_STATIC_SUPER_ROLE } = import.meta.env;
2024-03-28 16:22:18 +08:00
return (
VITE_AUTH_ROUTE_MODE === 'static' && userInfo.roles.map(role => role.toString()).includes(VITE_STATIC_SUPER_ROLE)
);
2024-03-26 11:47:11 +08:00
});
2024-03-08 17:59:45 +08:00
/** Is login */
const isLogin = computed(() => Boolean(token.value));
/** Reset auth store */
async function resetStore() {
const authStore = useAuthStore();
clearAuthStorage();
authStore.$reset();
2024-04-25 10:16:17 +08:00
if (!route.meta.constant) {
2024-03-08 17:59:45 +08:00
await toLogin();
}
routeStore.resetStore();
}
/**
* Login
*
* @param userName User name
* @param password Password
2024-03-26 11:47:11 +08:00
* @param [redirect=true] Whether to redirect after login. Default is `true`
2024-03-08 17:59:45 +08:00
*/
2024-03-26 11:47:11 +08:00
async function login(userName: string, password: string, redirect = true) {
2024-03-08 17:59:45 +08:00
startLoading();
const { data: loginToken, error } = await fetchLogin(userName, password);
if (!error) {
const pass = await loginByToken(loginToken);
if (pass) {
await routeStore.initAuthRoute();
2024-03-26 11:47:11 +08:00
if (redirect) {
await redirectFromLogin();
}
2024-03-08 17:59:45 +08:00
if (routeStore.isInitAuthRoute) {
window.$notification?.success({
2024-03-21 10:57:53 +08:00
title: $t('page.login.common.loginSuccess'),
2024-03-26 11:47:11 +08:00
content: $t('page.login.common.welcomeBack', { userName: userInfo.userName }),
2024-03-21 10:57:53 +08:00
duration: 4500
2024-03-08 17:59:45 +08:00
});
}
}
} else {
resetStore();
}
endLoading();
}
async function loginByToken(loginToken: Api.Auth.LoginToken) {
// 1. stored in the localStorage, the later requests need it in headers
localStg.set('token', loginToken.token);
2024-03-26 11:47:11 +08:00
// localStg.set('refreshToken', loginToken.refreshToken);
localStg.set('namespaceId', loginToken.namespaceIds[0].uniqueId);
2024-03-08 17:59:45 +08:00
const { data: info, error } = await fetchGetUserInfo();
if (!error) {
2024-03-26 11:47:11 +08:00
info!.userName = info?.username;
2024-05-10 17:15:06 +08:00
info!.roles = [roleTypeRecord[info.role]];
2024-03-08 17:59:45 +08:00
// 2. store user info
localStg.set('userInfo', info);
2024-03-26 11:47:11 +08:00
// 3. update store
2024-03-08 17:59:45 +08:00
token.value = loginToken.token;
Object.assign(userInfo, info);
return true;
}
return false;
}
2024-03-28 16:22:18 +08:00
async function getInfo() {
const { data: info, error } = await fetchGetUserInfo();
if (!error) {
info!.userName = info?.username;
2024-05-10 23:33:05 +08:00
info!.roles = [roleTypeRecord[info.role]];
2024-03-28 16:22:18 +08:00
localStg.set('userInfo', info);
Object.assign(userInfo, info);
return true;
}
resetStore();
return false;
}
2024-03-08 17:59:45 +08:00
return {
token,
userInfo,
2024-03-26 11:47:11 +08:00
isStaticSuper,
2024-03-08 17:59:45 +08:00
isLogin,
loginLoading,
resetStore,
2024-03-28 16:22:18 +08:00
login,
getInfo
2024-03-08 17:59:45 +08:00
};
});