CET-vue-3.0/src/store/modules/user.ts

305 lines
9.5 KiB
TypeScript
Raw Normal View History

2022-06-10 10:44:44 +08:00
import type { UserInfo, LoginInfo } from '/#/store';
2021-10-20 14:32:09 +08:00
import type { ErrorMessageMode } from '/#/axios';
import { defineStore } from 'pinia';
import { store } from '/@/store';
import { RoleEnum } from '/@/enums/roleEnum';
import { PageEnum } from '/@/enums/pageEnum';
2022-06-10 10:44:44 +08:00
import { ROLES_KEY, TOKEN_KEY, USER_INFO_KEY, LOGIN_INFO_KEY, DB_DICT_DATA_KEY, TENANT_ID } from '/@/enums/cacheEnum';
import { getAuthCache, setAuthCache, removeAuthCache } from '/@/utils/auth';
2022-06-10 10:44:44 +08:00
import { GetUserInfoModel, LoginParams, ThirdLoginParams } from '/@/api/sys/model/userModel';
import { doLogout, getUserInfo, loginApi, phoneLoginApi, thirdLogin } from '/@/api/sys/user';
2021-10-20 14:32:09 +08:00
import { useI18n } from '/@/hooks/web/useI18n';
import { useMessage } from '/@/hooks/web/useMessage';
import { router } from '/@/router';
import { usePermissionStore } from '/@/store/modules/permission';
import { RouteRecordRaw } from 'vue-router';
import { PAGE_NOT_FOUND_ROUTE } from '/@/router/routes/basic';
2022-03-10 09:47:29 +08:00
import { isArray } from '/@/utils/is';
import { useGlobSetting } from '/@/hooks/setting';
import { JDragConfigEnum } from '/@/enums/jeecgEnum';
2022-06-10 10:44:44 +08:00
import { useSso } from '/@/hooks/web/useSso';
2021-10-20 14:32:09 +08:00
interface UserState {
userInfo: Nullable<UserInfo>;
token?: string;
roleList: RoleEnum[];
2022-03-10 09:47:29 +08:00
dictItems?: [];
2021-10-20 14:32:09 +08:00
sessionTimeout?: boolean;
lastUpdateTime: number;
2022-06-10 10:44:44 +08:00
tenantid?: string | number;
2022-03-10 09:47:29 +08:00
loginInfo?: Nullable<LoginInfo>;
2021-10-20 14:32:09 +08:00
}
export const useUserStore = defineStore({
id: 'app-user',
state: (): UserState => ({
2022-03-10 09:47:29 +08:00
// 用户信息
2021-10-20 14:32:09 +08:00
userInfo: null,
// token
token: undefined,
2022-03-10 09:47:29 +08:00
// 角色列表
2021-10-20 14:32:09 +08:00
roleList: [],
2022-03-10 09:47:29 +08:00
// 字典
dictItems: [],
// session过期时间
2021-10-20 14:32:09 +08:00
sessionTimeout: false,
// Last fetch time
lastUpdateTime: 0,
2022-03-10 09:47:29 +08:00
//租户id
tenantid: '',
//登录返回信息
loginInfo: null,
2021-10-20 14:32:09 +08:00
}),
getters: {
getUserInfo(): UserInfo {
return this.userInfo || getAuthCache<UserInfo>(USER_INFO_KEY) || {};
},
2022-03-10 09:47:29 +08:00
getLoginInfo(): LoginInfo {
return this.loginInfo || getAuthCache<LoginInfo>(LOGIN_INFO_KEY) || {};
},
2021-10-20 14:32:09 +08:00
getToken(): string {
return this.token || getAuthCache<string>(TOKEN_KEY);
},
2022-06-10 10:44:44 +08:00
getAllDictItems(): [] {
2022-03-10 09:47:29 +08:00
return this.dictItems || getAuthCache(DB_DICT_DATA_KEY);
},
2021-10-20 14:32:09 +08:00
getRoleList(): RoleEnum[] {
return this.roleList.length > 0 ? this.roleList : getAuthCache<RoleEnum[]>(ROLES_KEY);
},
getSessionTimeout(): boolean {
return !!this.sessionTimeout;
},
getLastUpdateTime(): number {
return this.lastUpdateTime;
},
2022-06-10 10:44:44 +08:00
getTenant(): string | number {
return this.tenantid || getAuthCache<string | number>(TENANT_ID);
},
2021-10-20 14:32:09 +08:00
},
actions: {
setToken(info: string | undefined) {
2022-03-10 09:47:29 +08:00
this.token = info ? info : ''; // for null or undefined value
2021-10-20 14:32:09 +08:00
setAuthCache(TOKEN_KEY, info);
},
setRoleList(roleList: RoleEnum[]) {
this.roleList = roleList;
setAuthCache(ROLES_KEY, roleList);
},
2022-03-10 09:47:29 +08:00
setUserInfo(info: UserInfo | null) {
2021-10-20 14:32:09 +08:00
this.userInfo = info;
this.lastUpdateTime = new Date().getTime();
setAuthCache(USER_INFO_KEY, info);
},
2022-03-10 09:47:29 +08:00
setLoginInfo(info: LoginInfo | null) {
2022-06-10 10:44:44 +08:00
this.loginInfo = info;
2022-03-10 09:47:29 +08:00
setAuthCache(LOGIN_INFO_KEY, info);
2022-06-10 10:44:44 +08:00
},
2022-03-10 09:47:29 +08:00
setAllDictItems(dictItems) {
this.dictItems = dictItems;
setAuthCache(DB_DICT_DATA_KEY, dictItems);
},
2022-06-10 10:44:44 +08:00
setTenant(id) {
2022-03-10 09:47:29 +08:00
this.tenantid = id;
setAuthCache(TENANT_ID, id);
},
2021-10-20 14:32:09 +08:00
setSessionTimeout(flag: boolean) {
this.sessionTimeout = flag;
},
resetState() {
this.userInfo = null;
2022-03-10 09:47:29 +08:00
this.dictItems = [];
2021-10-20 14:32:09 +08:00
this.token = '';
this.roleList = [];
this.sessionTimeout = false;
},
/**
2022-03-10 09:47:29 +08:00
*
2021-10-20 14:32:09 +08:00
*/
async login(
params: LoginParams & {
goHome?: boolean;
mode?: ErrorMessageMode;
2022-06-10 10:44:44 +08:00
}
2021-10-20 14:32:09 +08:00
): Promise<GetUserInfoModel | null> {
try {
const { goHome = true, mode, ...loginParams } = params;
const data = await loginApi(loginParams, mode);
const { token, userInfo } = data;
2021-10-20 14:32:09 +08:00
// save token
this.setToken(token);
this.setTenant(userInfo.loginTenantId);
2022-06-10 10:44:44 +08:00
return this.afterLoginAction(goHome, data);
2021-10-20 14:32:09 +08:00
} catch (error) {
return Promise.reject(error);
}
},
2022-03-10 09:47:29 +08:00
/**
*
*/
async qrCodeLogin(token): Promise<GetUserInfoModel | null> {
try {
// save token
this.setToken(token);
2022-06-10 10:44:44 +08:00
return this.afterLoginAction(true, {});
2022-03-10 09:47:29 +08:00
} catch (error) {
return Promise.reject(error);
}
},
/**
*
* @param goHome
*/
2022-06-10 10:44:44 +08:00
async afterLoginAction(goHome?: boolean, data?: any): Promise<any | null> {
2022-03-10 09:47:29 +08:00
if (!this.getToken) return null;
//获取用户信息
const userInfo = await this.getUserInfoAction();
const sessionTimeout = this.sessionTimeout;
if (sessionTimeout) {
this.setSessionTimeout(false);
} else {
const permissionStore = usePermissionStore();
if (!permissionStore.isDynamicAddedRoute) {
const routes = await permissionStore.buildRoutesAction();
routes.forEach((route) => {
router.addRoute(route as unknown as RouteRecordRaw);
});
router.addRoute(PAGE_NOT_FOUND_ROUTE as unknown as RouteRecordRaw);
permissionStore.setDynamicAddedRoute(true);
}
await this.setLoginInfo({ ...data, isLogin: true });
//update-begin-author:liusq date:2022-5-5 for:登录成功后缓存拖拽模块的接口前缀
localStorage.setItem(JDragConfigEnum.DRAG_BASE_URL, useGlobSetting().domainUrl);
//update-end-author:liusq date:2022-5-5 for: 登录成功后缓存拖拽模块的接口前缀
2022-06-10 10:44:44 +08:00
goHome && (await router.replace((userInfo && userInfo.homePath) || PageEnum.BASE_HOME));
2022-03-10 09:47:29 +08:00
}
return data;
},
/**
*
* @param params
*/
2021-10-20 14:32:09 +08:00
async phoneLogin(
params: LoginParams & {
goHome?: boolean;
mode?: ErrorMessageMode;
2022-06-10 10:44:44 +08:00
}
2021-10-20 14:32:09 +08:00
): Promise<GetUserInfoModel | null> {
try {
const { goHome = true, mode, ...loginParams } = params;
const data = await phoneLoginApi(loginParams, mode);
const { token } = data;
// save token
this.setToken(token);
2022-06-10 10:44:44 +08:00
return this.afterLoginAction(goHome, data);
2021-10-20 14:32:09 +08:00
} catch (error) {
return Promise.reject(error);
}
},
2022-03-10 09:47:29 +08:00
/**
*
*/
async getUserInfoAction(): Promise<UserInfo | null> {
if (!this.getToken) {
return null;
}
2022-06-10 10:44:44 +08:00
const { userInfo, sysAllDictItems } = await getUserInfo();
if (userInfo) {
2022-03-10 09:47:29 +08:00
const { roles = [] } = userInfo;
if (isArray(roles)) {
const roleList = roles.map((item) => item.value) as RoleEnum[];
this.setRoleList(roleList);
} else {
userInfo.roles = [];
this.setRoleList([]);
}
2021-10-20 14:32:09 +08:00
this.setUserInfo(userInfo);
}
2022-03-10 09:47:29 +08:00
/**
*
* @updateBy:lsq
* @updateDate:2021-09-08
*/
2022-06-10 10:44:44 +08:00
if (sysAllDictItems) {
2022-03-10 09:47:29 +08:00
this.setAllDictItems(sysAllDictItems);
}
2021-10-20 14:32:09 +08:00
return userInfo;
},
/**
2022-03-10 09:47:29 +08:00
* 退
2021-10-20 14:32:09 +08:00
*/
async logout(goLogin = false) {
2022-03-10 09:47:29 +08:00
if (this.getToken) {
2021-10-20 14:32:09 +08:00
try {
await doLogout();
} catch {
console.log('注销Token失败');
}
}
// //update-begin-author:taoyan date:2022-5-5 for: src/layouts/default/header/index.vue showLoginSelect方法 获取tenantId 退出登录后再次登录依然能获取到值,没有清空
// let username:any = this.userInfo && this.userInfo.username;
// if(username){
// removeAuthCache(username)
// }
// //update-end-author:taoyan date:2022-5-5 for: src/layouts/default/header/index.vue showLoginSelect方法 获取tenantId 退出登录后再次登录依然能获取到值,没有清空
2022-03-10 09:47:29 +08:00
this.setToken('');
setAuthCache(TOKEN_KEY, null);
2021-10-20 14:32:09 +08:00
this.setSessionTimeout(false);
2022-03-10 09:47:29 +08:00
this.setUserInfo(null);
this.setLoginInfo(null);
this.setTenant(null);
//update-begin-author:liusq date:2022-5-5 for:退出登录后清除拖拽模块的接口前缀
localStorage.removeItem(JDragConfigEnum.DRAG_BASE_URL);
//update-end-author:liusq date:2022-5-5 for: 退出登录后清除拖拽模块的接口前缀
2022-03-10 09:47:29 +08:00
//如果开启单点登录,则跳转到单点统一登录中心
const openSso = useGlobSetting().openSso;
2022-06-10 10:44:44 +08:00
if (openSso == 'true') {
2022-03-10 09:47:29 +08:00
await useSso().ssoLoginOut();
}
2021-10-20 14:32:09 +08:00
2022-06-10 10:44:44 +08:00
goLogin && (await router.push(PageEnum.BASE_LOGIN));
2022-03-10 09:47:29 +08:00
},
2022-06-10 10:44:44 +08:00
/**
*
*/
async ThirdLogin(
params: ThirdLoginParams & {
goHome?: boolean;
mode?: ErrorMessageMode;
}
): Promise<any | null> {
2022-03-10 09:47:29 +08:00
try {
2022-06-10 10:44:44 +08:00
const { goHome = true, mode, ...ThirdLoginParams } = params;
const data = await thirdLogin(ThirdLoginParams, mode);
const { token } = data;
// save token
this.setToken(token);
return this.afterLoginAction(goHome, data);
2022-03-10 09:47:29 +08:00
} catch (error) {
2022-06-10 10:44:44 +08:00
return Promise.reject(error);
2022-03-10 09:47:29 +08:00
}
2022-06-10 10:44:44 +08:00
},
2021-10-20 14:32:09 +08:00
/**
2022-03-10 09:47:29 +08:00
* 退
2021-10-20 14:32:09 +08:00
*/
confirmLoginOut() {
const { createConfirm } = useMessage();
const { t } = useI18n();
createConfirm({
iconType: 'warning',
title: t('sys.app.logoutTip'),
content: t('sys.app.logoutMessage'),
onOk: async () => {
await this.logout(true);
},
});
},
},
});
// Need to be used outside the setup
export function useUserStoreWithOut() {
return useUserStore(store);
}