|
@@ -6,21 +6,20 @@ import { RoleEnum } from '@/enums/roleEnum';
|
|
|
import { PageEnum } from '@/enums/pageEnum';
|
|
import { PageEnum } from '@/enums/pageEnum';
|
|
|
import { ROLES_KEY, TOKEN_KEY, USER_INFO_KEY } from '@/enums/cacheEnum';
|
|
import { ROLES_KEY, TOKEN_KEY, USER_INFO_KEY } from '@/enums/cacheEnum';
|
|
|
import { getAuthCache, setAuthCache } from '@/utils/auth';
|
|
import { getAuthCache, setAuthCache } from '@/utils/auth';
|
|
|
-import { GetUserInfoModel, LoginParams } from '@/api/sys/model/userModel';
|
|
|
|
|
-import { doLogout, getUserInfo, loginApi } from '@/api/sys/user';
|
|
|
|
|
|
|
+import { GetUserInfoModel, LoginParams, LoginResultModel } from '@/api/sys/model/userModel';
|
|
|
|
|
+import { doLogout, loginApi } from '@/api/sys/user';
|
|
|
import { useI18n } from '@/hooks/web/useI18n';
|
|
import { useI18n } from '@/hooks/web/useI18n';
|
|
|
import { useMessage } from '@/hooks/web/useMessage';
|
|
import { useMessage } from '@/hooks/web/useMessage';
|
|
|
import { router } from '@/router';
|
|
import { router } from '@/router';
|
|
|
import { usePermissionStore } from '@/store/modules/permission';
|
|
import { usePermissionStore } from '@/store/modules/permission';
|
|
|
import { RouteRecordRaw } from 'vue-router';
|
|
import { RouteRecordRaw } from 'vue-router';
|
|
|
import { PAGE_NOT_FOUND_ROUTE } from '@/router/routes/basic';
|
|
import { PAGE_NOT_FOUND_ROUTE } from '@/router/routes/basic';
|
|
|
-import { isArray } from '@/utils/is';
|
|
|
|
|
import { h } from 'vue';
|
|
import { h } from 'vue';
|
|
|
|
|
|
|
|
interface UserState {
|
|
interface UserState {
|
|
|
userInfo: Nullable<UserInfo>;
|
|
userInfo: Nullable<UserInfo>;
|
|
|
token?: string;
|
|
token?: string;
|
|
|
- roleList: RoleEnum[];
|
|
|
|
|
|
|
+ roleList: string[];
|
|
|
sessionTimeout?: boolean;
|
|
sessionTimeout?: boolean;
|
|
|
lastUpdateTime: number;
|
|
lastUpdateTime: number;
|
|
|
}
|
|
}
|
|
@@ -46,7 +45,7 @@ export const useUserStore = defineStore({
|
|
|
getToken(state): string {
|
|
getToken(state): string {
|
|
|
return state.token || getAuthCache<string>(TOKEN_KEY);
|
|
return state.token || getAuthCache<string>(TOKEN_KEY);
|
|
|
},
|
|
},
|
|
|
- getRoleList(state): RoleEnum[] {
|
|
|
|
|
|
|
+ getRoleList(state): string[] {
|
|
|
return state.roleList.length > 0 ? state.roleList : getAuthCache<RoleEnum[]>(ROLES_KEY);
|
|
return state.roleList.length > 0 ? state.roleList : getAuthCache<RoleEnum[]>(ROLES_KEY);
|
|
|
},
|
|
},
|
|
|
getSessionTimeout(state): boolean {
|
|
getSessionTimeout(state): boolean {
|
|
@@ -61,7 +60,7 @@ export const useUserStore = defineStore({
|
|
|
this.token = info ? info : ''; // for null or undefined value
|
|
this.token = info ? info : ''; // for null or undefined value
|
|
|
setAuthCache(TOKEN_KEY, info);
|
|
setAuthCache(TOKEN_KEY, info);
|
|
|
},
|
|
},
|
|
|
- setRoleList(roleList: RoleEnum[]) {
|
|
|
|
|
|
|
+ setRoleList(roleList: string[]) {
|
|
|
this.roleList = roleList;
|
|
this.roleList = roleList;
|
|
|
setAuthCache(ROLES_KEY, roleList);
|
|
setAuthCache(ROLES_KEY, roleList);
|
|
|
},
|
|
},
|
|
@@ -91,25 +90,31 @@ export const useUserStore = defineStore({
|
|
|
try {
|
|
try {
|
|
|
const { goHome = true, mode, ...loginParams } = params;
|
|
const { goHome = true, mode, ...loginParams } = params;
|
|
|
const data = await loginApi(loginParams, mode);
|
|
const data = await loginApi(loginParams, mode);
|
|
|
- const { token } = data;
|
|
|
|
|
|
|
|
|
|
- // save token
|
|
|
|
|
- this.setToken(token);
|
|
|
|
|
- return this.afterLoginAction(goHome);
|
|
|
|
|
|
|
+ return this.afterLoginAction(data, goHome);
|
|
|
} catch (error) {
|
|
} catch (error) {
|
|
|
return Promise.reject(error);
|
|
return Promise.reject(error);
|
|
|
}
|
|
}
|
|
|
},
|
|
},
|
|
|
- async afterLoginAction(goHome?: boolean): Promise<GetUserInfoModel | null> {
|
|
|
|
|
|
|
+ async afterLoginAction(
|
|
|
|
|
+ loginResult: LoginResultModel,
|
|
|
|
|
+ goHome?: boolean,
|
|
|
|
|
+ ): Promise<GetUserInfoModel | null> {
|
|
|
|
|
+ const { token, user: userInfo, permissions, roles } = loginResult;
|
|
|
|
|
+ this.setToken(token);
|
|
|
|
|
+ this.setRoleList(roles);
|
|
|
if (!this.getToken) return null;
|
|
if (!this.getToken) return null;
|
|
|
// get user info
|
|
// get user info
|
|
|
- const userInfo = await this.getUserInfoAction();
|
|
|
|
|
|
|
+ this.setUserInfo({
|
|
|
|
|
+ ...userInfo,
|
|
|
|
|
+ });
|
|
|
|
|
|
|
|
const sessionTimeout = this.sessionTimeout;
|
|
const sessionTimeout = this.sessionTimeout;
|
|
|
if (sessionTimeout) {
|
|
if (sessionTimeout) {
|
|
|
this.setSessionTimeout(false);
|
|
this.setSessionTimeout(false);
|
|
|
} else {
|
|
} else {
|
|
|
const permissionStore = usePermissionStore();
|
|
const permissionStore = usePermissionStore();
|
|
|
|
|
+ permissionStore.setPermCodeList(permissions);
|
|
|
if (!permissionStore.isDynamicAddedRoute) {
|
|
if (!permissionStore.isDynamicAddedRoute) {
|
|
|
const routes = await permissionStore.buildRoutesAction();
|
|
const routes = await permissionStore.buildRoutesAction();
|
|
|
routes.forEach((route) => {
|
|
routes.forEach((route) => {
|
|
@@ -123,18 +128,19 @@ export const useUserStore = defineStore({
|
|
|
return userInfo;
|
|
return userInfo;
|
|
|
},
|
|
},
|
|
|
async getUserInfoAction(): Promise<UserInfo | null> {
|
|
async getUserInfoAction(): Promise<UserInfo | null> {
|
|
|
- if (!this.getToken) return null;
|
|
|
|
|
- const userInfo = await getUserInfo();
|
|
|
|
|
- const { roles = [] } = userInfo;
|
|
|
|
|
- if (isArray(roles)) {
|
|
|
|
|
- const roleList = roles.map((item) => item.value) as RoleEnum[];
|
|
|
|
|
- this.setRoleList(roleList);
|
|
|
|
|
- } else {
|
|
|
|
|
- userInfo.roles = [];
|
|
|
|
|
- this.setRoleList([]);
|
|
|
|
|
- }
|
|
|
|
|
- this.setUserInfo(userInfo);
|
|
|
|
|
- return userInfo;
|
|
|
|
|
|
|
+ // if (!this.getToken) return null;
|
|
|
|
|
+ // const userInfo = await getUserInfo();
|
|
|
|
|
+ // const { roles = [] } = userInfo;
|
|
|
|
|
+ // if (isArray(roles)) {
|
|
|
|
|
+ // const roleList = roles.map((item) => item.value) as RoleEnum[];
|
|
|
|
|
+ // this.setRoleList(roleList);
|
|
|
|
|
+ // } else {
|
|
|
|
|
+ // userInfo.roles = [];
|
|
|
|
|
+ // this.setRoleList([]);
|
|
|
|
|
+ // }
|
|
|
|
|
+ // this.setUserInfo(userInfo);
|
|
|
|
|
+ // return userInfo;
|
|
|
|
|
+ return this.getUserInfo;
|
|
|
},
|
|
},
|
|
|
/**
|
|
/**
|
|
|
* @description: logout
|
|
* @description: logout
|