user.ts 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252
  1. import { defHttp } from '/@/utils/http/axios';
  2. import { LoginParams, LoginResultModel, GetUserInfoModel, AutoLoginParams, TokenInfo } from './model/userModel';
  3. import { ErrorMessageMode, SuccessMessageMode } from '/#/axios';
  4. import { useMessage } from '/@/hooks/web/useMessage';
  5. import { useUserStoreWithOut } from '/@/store/modules/user';
  6. import { setAuthCache } from '/@/utils/auth';
  7. import { TOKEN_KEY } from '/@/enums/cacheEnum';
  8. import { router } from '/@/router';
  9. import { PageEnum } from '/@/enums/pageEnum';
  10. const { createErrorModal } = useMessage();
  11. enum Api {
  12. Login = '/sys/login',
  13. phoneLogin = '/sys/phoneLogin',
  14. Logout = '/sys/logout',
  15. autoLogin = '/sys/autoLogin',
  16. GetUserInfo = '/sys/user/getUserInfo',
  17. tokenLogin = '/sys/luanLogin',
  18. // 获取系统权限
  19. // 1、查询用户拥有的按钮/表单访问权限
  20. // 2、所有权限
  21. // 3、系统安全模式
  22. GetPermCode = '/sys/permissionNew/getPermCode',
  23. UserGetPermCode = '/sys/permissionNew/getUserPermissionByToken',
  24. //新加的获取图形验证码的接口
  25. getInputCode = '/sys/randomImage',
  26. //获取短信验证码的接口
  27. getCaptcha = '/sys/sms',
  28. //注册接口
  29. registerApi = '/sys/user/register',
  30. //校验用户接口
  31. checkOnlyUser = '/sys/user/checkOnlyUser',
  32. //SSO登录校验
  33. validateCasLogin = '/sys/cas/client/validateLogin',
  34. //校验手机号
  35. phoneVerify = '/sys/user/phoneVerification',
  36. //修改密码
  37. passwordChange = '/sys/user/passwordChange',
  38. //第三方登录
  39. thirdLogin = '/sys/thirdLogin/getLoginUser',
  40. //第三方登录
  41. getThirdCaptcha = '/sys/thirdSms',
  42. //获取二维码信息
  43. getLoginQrcode = '/sys/getLoginQrcode',
  44. //监控二维码扫描状态
  45. getQrcodeToken = '/sys/getQrcodeToken',
  46. }
  47. /**
  48. * @description: user login api
  49. */
  50. export function loginApi(params: LoginParams, mode: ErrorMessageMode = 'modal', successMode: SuccessMessageMode = 'success') {
  51. return defHttp.post<LoginResultModel>(
  52. {
  53. url: Api.Login,
  54. params,
  55. },
  56. {
  57. successMessageMode: successMode,
  58. errorMessageMode: mode,
  59. }
  60. );
  61. }
  62. /**
  63. * @description: user auto login api
  64. */
  65. export function autoLoginApi(params: AutoLoginParams, mode: ErrorMessageMode = 'modal', successMode: SuccessMessageMode = 'success') {
  66. return defHttp.get<LoginResultModel>(
  67. {
  68. url: Api.autoLogin,
  69. params,
  70. headers: {
  71. token: 'MTIzNDU2',
  72. },
  73. },
  74. {
  75. successMessageMode: successMode,
  76. errorMessageMode: mode,
  77. }
  78. );
  79. }
  80. /**
  81. * @description: user phoneLogin api
  82. */
  83. export function phoneLoginApi(params: LoginParams, mode: ErrorMessageMode = 'modal') {
  84. return defHttp.post<LoginResultModel>(
  85. {
  86. url: Api.phoneLogin,
  87. params,
  88. },
  89. {
  90. errorMessageMode: mode,
  91. }
  92. );
  93. }
  94. export function tokenLogin(params: TokenInfo, mode: ErrorMessageMode = 'modal', successMode: SuccessMessageMode = 'success') {
  95. return defHttp.post<GetUserInfoModel>(
  96. {
  97. url: Api.tokenLogin,
  98. data: params.token,
  99. },
  100. {
  101. successMessageMode: successMode,
  102. errorMessageMode: mode,
  103. }
  104. );
  105. }
  106. /**
  107. * @description: getUserInfo
  108. */
  109. export function getUserInfo() {
  110. return defHttp.get<GetUserInfoModel>({ url: Api.GetUserInfo }, {}).catch((e) => {
  111. // update-begin--author:zyf---date:20220425---for:【VUEN-76】捕获接口超时异常,跳转到登录界面
  112. if (e && (e.message.includes('timeout') || e.message.includes('401'))) {
  113. //接口不通时跳转到登录界面
  114. const userStore = useUserStoreWithOut();
  115. userStore.setToken('');
  116. setAuthCache(TOKEN_KEY, null);
  117. // update-begin-author:sunjianlei date:20230306 for: 修复登录成功后,没有正确重定向的问题
  118. router.push({
  119. path: PageEnum.BASE_LOGIN,
  120. query: {
  121. // 传入当前的路由,登录成功后跳转到当前路由
  122. redirect: router.currentRoute.value.fullPath,
  123. },
  124. });
  125. // update-end-author:sunjianlei date:20230306 for: 修复登录成功后,没有正确重定向的问题
  126. }
  127. // update-end--author:zyf---date:20220425---for:【VUEN-76】捕获接口超时异常,跳转到登录界面
  128. });
  129. }
  130. export function getPermCode() {
  131. return defHttp.get({ url: Api.GetPermCode });
  132. }
  133. export function getUserPermissionByToken() {
  134. return defHttp.get({ url: Api.UserGetPermCode });
  135. }
  136. export function doLogout() {
  137. return defHttp.get({ url: Api.Logout });
  138. }
  139. export function getCodeInfo(currdatetime) {
  140. const url = Api.getInputCode + `/${currdatetime}`;
  141. return defHttp.get({ url: url });
  142. }
  143. /**
  144. * @description: 获取短信验证码
  145. */
  146. export function getCaptcha(params) {
  147. return new Promise((resolve, reject) => {
  148. defHttp.post({ url: Api.getCaptcha, params }, { isTransformResponse: false }).then((res) => {
  149. console.log(res);
  150. if (res.success) {
  151. resolve(true);
  152. } else {
  153. createErrorModal({ title: '错误提示', content: res.message || '未知问题' });
  154. reject();
  155. }
  156. });
  157. });
  158. }
  159. /**
  160. * @description: 注册接口
  161. */
  162. export function register(params) {
  163. return defHttp.post({ url: Api.registerApi, params }, { isReturnNativeResponse: true });
  164. }
  165. /**
  166. *校验用户是否存在
  167. * @param params
  168. */
  169. export const checkOnlyUser = (params) => defHttp.get({ url: Api.checkOnlyUser, params }, { isTransformResponse: false });
  170. /**
  171. *校验手机号码
  172. * @param params
  173. */
  174. export const phoneVerify = (params) => defHttp.post({ url: Api.phoneVerify, params }, { isTransformResponse: false });
  175. /**
  176. *密码修改
  177. * @param params
  178. */
  179. export const passwordChange = (params) => defHttp.get({ url: Api.passwordChange, params }, { isTransformResponse: false });
  180. /**
  181. * @description: 第三方登录
  182. */
  183. export function thirdLogin(params, mode: ErrorMessageMode = 'modal') {
  184. //==========begin 第三方登录/auth2登录需要传递租户id===========
  185. let tenantId = '0';
  186. if (!params.tenantId) {
  187. tenantId = params.tenantId;
  188. }
  189. //==========end 第三方登录/auth2登录需要传递租户id===========
  190. return defHttp.get<LoginResultModel>(
  191. {
  192. url: `${Api.thirdLogin}/${params.token}/${params.thirdType}/${tenantId}`,
  193. },
  194. {
  195. errorMessageMode: mode,
  196. }
  197. );
  198. }
  199. /**
  200. * @description: 获取第三方短信验证码
  201. */
  202. export function setThirdCaptcha(params) {
  203. return new Promise((resolve, reject) => {
  204. defHttp.post({ url: Api.getThirdCaptcha, params }, { isTransformResponse: false }).then((res) => {
  205. console.log(res);
  206. if (res.success) {
  207. resolve(true);
  208. } else {
  209. createErrorModal({ title: '错误提示', content: res.message || '未知问题' });
  210. reject();
  211. }
  212. });
  213. });
  214. }
  215. /**
  216. * 获取登录二维码信息
  217. */
  218. export function getLoginQrcode() {
  219. const url = Api.getLoginQrcode;
  220. return defHttp.get({ url: url });
  221. }
  222. /**
  223. * 监控扫码状态
  224. */
  225. export function getQrcodeToken(params) {
  226. const url = Api.getQrcodeToken;
  227. return defHttp.get({ url: url, params });
  228. }
  229. /**
  230. * SSO登录校验
  231. */
  232. export async function validateCasLogin(params) {
  233. const url = Api.validateCasLogin;
  234. return defHttp.get({ url: url, params });
  235. }