user.ts 6.5 KB

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