|  | @@ -10,11 +10,12 @@ import { ROLES_KEY, TOKEN_KEY, USER_INFO_KEY } from '/@/enums/cacheEnum'
 | 
												
													
														
															|  |  import { getAuthCache, setAuthCache, getToken, removeAuthCache } from '/@/utils/auth'
 |  |  import { getAuthCache, setAuthCache, getToken, removeAuthCache } from '/@/utils/auth'
 | 
												
													
														
															|  |  import {
 |  |  import {
 | 
												
													
														
															|  |    GetUserInfoByUserIdModel,
 |  |    GetUserInfoByUserIdModel,
 | 
												
													
														
															|  | 
 |  | +  GetUserInfoModel,
 | 
												
													
														
															|  |    // GetUserInfoByUserIdParams,
 |  |    // GetUserInfoByUserIdParams,
 | 
												
													
														
															|  |    LoginParams
 |  |    LoginParams
 | 
												
													
														
															|  |  } from '/@/api/sys/model/userModel'
 |  |  } from '/@/api/sys/model/userModel'
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  | -import { loginApi, getXsrfToken, logoutApi, getAccountGroupList } from '/@/api/sys/user'
 |  | 
 | 
												
													
														
															|  | 
 |  | +import { loginApi, getXsrfToken, logoutApi, getAccountGroupList, getUserInfo } 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'
 | 
												
											
												
													
														
															|  | @@ -23,7 +24,7 @@ import { PermGroupItem } from '/@/api/sys/model/managerModel'
 | 
												
													
														
															|  |  import { getPermGroupList } from '/@/api/sys/manager'
 |  |  import { getPermGroupList } from '/@/api/sys/manager'
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |  interface UserState {
 |  |  interface UserState {
 | 
												
													
														
															|  | -  userInfo: Nullable<UserInfo>
 |  | 
 | 
												
													
														
															|  | 
 |  | +  userInfo: Nullable<GetUserInfoModel>
 | 
												
													
														
															|  |    token?: string
 |  |    token?: string
 | 
												
													
														
															|  |    roleList: RoleEnum[]
 |  |    roleList: RoleEnum[]
 | 
												
													
														
															|  |    accountGroups: string[]
 |  |    accountGroups: string[]
 | 
												
											
												
													
														
															|  | @@ -38,9 +39,11 @@ export const useUserStore = defineStore({
 | 
												
													
														
															|  |      // token
 |  |      // token
 | 
												
													
														
															|  |      token: undefined,
 |  |      token: undefined,
 | 
												
													
														
															|  |      // roleList
 |  |      // roleList
 | 
												
													
														
															|  | -    roleList: [],
 |  | 
 | 
												
													
														
															|  | 
 |  | +    rolesList: [],
 | 
												
													
														
															|  |      accountGroups: [],
 |  |      accountGroups: [],
 | 
												
													
														
															|  | -    permGroups: []
 |  | 
 | 
												
													
														
															|  | 
 |  | +    permGroups: [],
 | 
												
													
														
															|  | 
 |  | +    // Whether the login expired
 | 
												
													
														
															|  | 
 |  | +    sessionTimeout: false
 | 
												
													
														
															|  |    }),
 |  |    }),
 | 
												
													
														
															|  |    getters: {
 |  |    getters: {
 | 
												
													
														
															|  |      getUserInfo(): UserInfo {
 |  |      getUserInfo(): UserInfo {
 | 
												
											
												
													
														
															|  | @@ -50,13 +53,16 @@ export const useUserStore = defineStore({
 | 
												
													
														
															|  |        return this.token || getAuthCache<string>(TOKEN_KEY)
 |  |        return this.token || getAuthCache<string>(TOKEN_KEY)
 | 
												
													
														
															|  |      },
 |  |      },
 | 
												
													
														
															|  |      getRoleList(): RoleEnum[] {
 |  |      getRoleList(): RoleEnum[] {
 | 
												
													
														
															|  | -      return this.roleList.length > 0 ? this.roleList : getAuthCache<RoleEnum[]>(ROLES_KEY)
 |  | 
 | 
												
													
														
															|  | 
 |  | +      return this.rolesList.length ? this.rolesList : getAuthCache<RoleEnum[]>(ROLES_KEY)
 | 
												
													
														
															|  |      },
 |  |      },
 | 
												
													
														
															|  |      getGroupList(): string[] {
 |  |      getGroupList(): string[] {
 | 
												
													
														
															|  |        return this.accountGroups
 |  |        return this.accountGroups
 | 
												
													
														
															|  |      },
 |  |      },
 | 
												
													
														
															|  |      getPermGroupList(): PermGroupItem[] {
 |  |      getPermGroupList(): PermGroupItem[] {
 | 
												
													
														
															|  |        return this.permGroups
 |  |        return this.permGroups
 | 
												
													
														
															|  | 
 |  | +    },
 | 
												
													
														
															|  | 
 |  | +    getSessionTimeout(): boolean {
 | 
												
													
														
															|  | 
 |  | +      return !!this.sessionTimeout
 | 
												
													
														
															|  |      }
 |  |      }
 | 
												
													
														
															|  |    },
 |  |    },
 | 
												
													
														
															|  |    actions: {
 |  |    actions: {
 | 
												
											
												
													
														
															|  | @@ -65,7 +71,9 @@ export const useUserStore = defineStore({
 | 
												
													
														
															|  |        setAuthCache(TOKEN_KEY, info)
 |  |        setAuthCache(TOKEN_KEY, info)
 | 
												
													
														
															|  |      },
 |  |      },
 | 
												
													
														
															|  |      setRoleList(roleList: RoleEnum[]) {
 |  |      setRoleList(roleList: RoleEnum[]) {
 | 
												
													
														
															|  | -      this.roleList = roleList
 |  | 
 | 
												
													
														
															|  | 
 |  | +      console.log('roleList', roleList)
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  | 
 |  | +      this.rolesList = roleList
 | 
												
													
														
															|  |        setAuthCache(ROLES_KEY, roleList)
 |  |        setAuthCache(ROLES_KEY, roleList)
 | 
												
													
														
															|  |      },
 |  |      },
 | 
												
													
														
															|  |      setUserInfo(info: UserInfo) {
 |  |      setUserInfo(info: UserInfo) {
 | 
												
											
												
													
														
															|  | @@ -78,10 +86,14 @@ export const useUserStore = defineStore({
 | 
												
													
														
															|  |      setPermGroupList(permList: PermGroupItem[]) {
 |  |      setPermGroupList(permList: PermGroupItem[]) {
 | 
												
													
														
															|  |        this.permGroups = permList
 |  |        this.permGroups = permList
 | 
												
													
														
															|  |      },
 |  |      },
 | 
												
													
														
															|  | 
 |  | +    setSessionTimeout(flag: boolean) {
 | 
												
													
														
															|  | 
 |  | +      this.sessionTimeout = flag
 | 
												
													
														
															|  | 
 |  | +    },
 | 
												
													
														
															|  |      resetState() {
 |  |      resetState() {
 | 
												
													
														
															|  |        this.userInfo = null
 |  |        this.userInfo = null
 | 
												
													
														
															|  |        this.token = ''
 |  |        this.token = ''
 | 
												
													
														
															|  | -      this.roleList = []
 |  | 
 | 
												
													
														
															|  | 
 |  | +      this.rolesList = []
 | 
												
													
														
															|  | 
 |  | +      this.sessionTimeout = false
 | 
												
													
														
															|  |      },
 |  |      },
 | 
												
													
														
															|  |      /**
 |  |      /**
 | 
												
													
														
															|  |       * @description: login
 |  |       * @description: login
 | 
												
											
												
													
														
															|  | @@ -95,22 +107,31 @@ export const useUserStore = defineStore({
 | 
												
													
														
															|  |        try {
 |  |        try {
 | 
												
													
														
															|  |          const { goHome = true, mode, ...loginParams } = params
 |  |          const { goHome = true, mode, ...loginParams } = params
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  | -        const userInfo = await loginApi(loginParams, mode)
 |  | 
 | 
												
													
														
															|  | 
 |  | +        await loginApi(loginParams, mode)
 | 
												
													
														
															|  |          // get user info
 |  |          // get user info
 | 
												
													
														
															|  | -        // const userInfo = await this.getUserInfoAction({ userId })
 |  | 
 | 
												
													
														
															|  | -        this.setRoleList([RoleEnum.SUPER])
 |  | 
 | 
												
													
														
															|  | -        // if (isAdmin) {
 |  | 
 | 
												
													
														
															|  | -        // }
 |  | 
 | 
												
													
														
															|  | -
 |  | 
 | 
												
													
														
															|  | 
 |  | +        const userInfo = await this.getUserInfoAction()
 | 
												
													
														
															|  |          // const roleList = roles.map(item => item.value) as RoleEnum[]
 |  |          // const roleList = roles.map(item => item.value) as RoleEnum[]
 | 
												
													
														
															|  | -        this.setUserInfo({ ...userInfo })
 |  | 
 | 
												
													
														
															|  | -        goHome && (await router.replace(PageEnum.BASE_HOME))
 |  | 
 | 
												
													
														
															|  | 
 |  | +        const sessionTimeout = this.sessionTimeout
 | 
												
													
														
															|  | 
 |  | +        sessionTimeout && this.setSessionTimeout(false)
 | 
												
													
														
															|  | 
 |  | +        !sessionTimeout && goHome && (await router.replace(PageEnum.BASE_HOME))
 | 
												
													
														
															|  |          return userInfo
 |  |          return userInfo
 | 
												
													
														
															|  | 
 |  | +        return true
 | 
												
													
														
															|  |        } catch (error) {
 |  |        } catch (error) {
 | 
												
													
														
															|  | -        return null
 |  | 
 | 
												
													
														
															|  | 
 |  | +        return Promise.reject(error)
 | 
												
													
														
															|  |        }
 |  |        }
 | 
												
													
														
															|  |      },
 |  |      },
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  | 
 |  | +    async getUserInfoAction() {
 | 
												
													
														
															|  | 
 |  | +      const userInfo = await getUserInfo()
 | 
												
													
														
															|  | 
 |  | +      this.setUserInfo({ ...userInfo })
 | 
												
													
														
															|  | 
 |  | +      if (userInfo?.isAdmin) {
 | 
												
													
														
															|  | 
 |  | +        this.setRoleList([RoleEnum.ADMIN])
 | 
												
													
														
															|  | 
 |  | +      } else {
 | 
												
													
														
															|  | 
 |  | +        this.setRoleList(userInfo.roles)
 | 
												
													
														
															|  | 
 |  | +      }
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  | 
 |  | +      return userInfo
 | 
												
													
														
															|  | 
 |  | +    },
 | 
												
													
														
															|  |      async fetchGroupList() {
 |  |      async fetchGroupList() {
 | 
												
													
														
															|  |        try {
 |  |        try {
 | 
												
													
														
															|  |          const data = await getAccountGroupList()
 |  |          const data = await getAccountGroupList()
 |