user.ts 7.3 KB

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