ruoyi-plus-soybean/src/store/modules/auth/index.ts

159 lines
3.7 KiB
TypeScript
Raw Normal View History

2023-12-14 21:45:29 +08:00
import { computed, reactive, ref } from 'vue';
2024-04-16 00:03:00 +08:00
import { useRoute } from 'vue-router';
import { defineStore } from 'pinia';
2023-11-17 08:45:00 +08:00
import { useLoading } from '@sa/hooks';
import { SetupStoreId } from '@/enum';
import { useRouterPush } from '@/hooks/common/router';
2024-09-02 09:34:34 +08:00
import { fetchGetUserInfo, fetchLogin, fetchLogout } from '@/service/api';
2023-11-17 08:45:00 +08:00
import { localStg } from '@/utils/storage';
2024-08-16 16:33:11 +08:00
// import { $t } from '@/locales';
2023-12-14 21:45:29 +08:00
import { useRouteStore } from '../route';
2024-06-15 00:49:24 +08:00
import { useTabStore } from '../tab';
import { clearAuthStorage, getToken } from './shared';
2023-11-17 08:45:00 +08:00
export const useAuthStore = defineStore(SetupStoreId.Auth, () => {
2024-04-16 00:03:00 +08:00
const route = useRoute();
2023-11-17 08:45:00 +08:00
const routeStore = useRouteStore();
const tabStore = useTabStore();
const { toLogin, redirectFromLogin } = useRouterPush(false);
2023-11-17 08:45:00 +08:00
const { loading: loginLoading, startLoading, endLoading } = useLoading();
const token = ref(getToken());
const userInfo: Api.Auth.UserInfo = reactive({
2024-08-16 16:33:11 +08:00
user: undefined,
roles: [],
2024-08-16 16:33:11 +08:00
permissions: []
});
2023-11-17 08:45:00 +08:00
2024-03-24 15:39:41 +08:00
/** is super role in static route */
const isStaticSuper = computed(() => {
const { VITE_AUTH_ROUTE_MODE, VITE_STATIC_SUPER_ROLE } = import.meta.env;
return VITE_AUTH_ROUTE_MODE === 'static' && userInfo.roles.includes(VITE_STATIC_SUPER_ROLE);
});
2023-12-14 21:45:29 +08:00
/** Is login */
2023-11-17 08:45:00 +08:00
const isLogin = computed(() => Boolean(token.value));
2023-12-14 21:45:29 +08:00
/** Reset auth store */
2023-11-17 08:45:00 +08:00
async function resetStore() {
const authStore = useAuthStore();
clearAuthStorage();
authStore.$reset();
if (!route.meta.constant) {
2023-11-17 08:45:00 +08:00
await toLogin();
}
tabStore.cacheTabs();
2023-11-17 08:45:00 +08:00
routeStore.resetStore();
}
2024-09-02 09:34:34 +08:00
async function logout() {
await fetchLogout();
resetStore();
}
2023-11-17 08:45:00 +08:00
/**
2023-12-14 21:45:29 +08:00
* Login
*
2024-03-24 15:39:41 +08:00
* @param [redirect=true] Whether to redirect after login. Default is `true`
2023-11-17 08:45:00 +08:00
*/
2024-08-16 16:33:11 +08:00
async function login(loginForm: Api.Auth.LoginForm, redirect = true) {
2023-11-17 08:45:00 +08:00
startLoading();
2024-08-16 16:33:11 +08:00
const { VITE_APP_CLIENT_ID } = import.meta.env;
const loginData: Api.Auth.LoginData = {
...loginForm,
clientId: VITE_APP_CLIENT_ID!,
grantType: 'password'
};
const { data: loginToken, error } = await fetchLogin(loginData);
2023-11-17 08:45:00 +08:00
if (!error) {
const pass = await loginByToken(loginToken);
2023-11-17 08:45:00 +08:00
if (pass) {
await routeStore.initAuthRoute();
2023-11-17 08:45:00 +08:00
2024-03-24 15:39:41 +08:00
if (redirect) {
await redirectFromLogin();
}
2023-11-17 08:45:00 +08:00
if (routeStore.isInitAuthRoute) {
2024-08-16 16:33:11 +08:00
// window.$notification?.success({
// title: $t('page.login.common.loginSuccess'),
// content: $t('page.login.common.welcomeBack', { userName: userInfo.userName }),
// duration: 4500
// });
}
}
} else {
2023-11-17 08:45:00 +08:00
resetStore();
}
endLoading();
2024-08-16 16:33:11 +08:00
return error ? Promise.reject(error) : Promise.resolve();
}
2023-11-17 08:45:00 +08:00
async function loginByToken(loginToken: Api.Auth.LoginToken) {
// 1. stored in the localStorage, the later requests need it in headers
2024-08-16 16:33:11 +08:00
localStg.set('token', loginToken.access_token);
localStg.set('refreshToken', loginToken.refresh_token);
2023-11-17 08:45:00 +08:00
// 2. get user info
const pass = await getUserInfo();
if (pass) {
2024-08-16 16:33:11 +08:00
token.value = loginToken.access_token;
return true;
}
return false;
}
async function getUserInfo() {
const { data: info, error } = await fetchGetUserInfo();
if (!error) {
// update store
Object.assign(userInfo, info);
return true;
}
2023-11-17 08:45:00 +08:00
return false;
2023-11-17 08:45:00 +08:00
}
async function initUserInfo() {
const hasToken = getToken();
if (hasToken) {
const pass = await getUserInfo();
if (!pass) {
resetStore();
}
}
}
2023-11-17 08:45:00 +08:00
return {
token,
userInfo,
2024-03-24 15:39:41 +08:00
isStaticSuper,
2023-11-17 08:45:00 +08:00
isLogin,
loginLoading,
resetStore,
login,
2024-09-02 09:34:34 +08:00
logout,
initUserInfo
2023-11-17 08:45:00 +08:00
};
});