index.js 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226
  1. "use strict";
  2. const common_vendor = require("../../common/vendor.js");
  3. const sheep_config_index = require("../config/index.js");
  4. const sheep_store_index = require("../store/index.js");
  5. const sheep_platform_index = require("../platform/index.js");
  6. const sheep_hooks_useModal = require("../hooks/useModal.js");
  7. const sheep_api_member_auth = require("../api/member/auth.js");
  8. const options = {
  9. // 显示操作成功消息 默认不显示
  10. showSuccess: false,
  11. // 成功提醒 默认使用后端返回值
  12. successMsg: "",
  13. // 显示失败消息 默认显示
  14. showError: true,
  15. // 失败提醒 默认使用后端返回信息
  16. errorMsg: "",
  17. // 显示请求时loading模态框 默认显示
  18. showLoading: true,
  19. // loading提醒文字
  20. loadingMsg: "加载中",
  21. // 需要授权才能请求 默认放开
  22. auth: false
  23. // ...
  24. };
  25. let LoadingInstance = {
  26. target: null,
  27. count: 0
  28. };
  29. function closeLoading() {
  30. if (LoadingInstance.count > 0)
  31. LoadingInstance.count--;
  32. if (LoadingInstance.count === 0)
  33. common_vendor.index.hideLoading();
  34. }
  35. const http = new common_vendor.Request({
  36. baseURL: sheep_config_index.baseUrl + sheep_config_index.apiPath,
  37. timeout: 8e3,
  38. method: "GET",
  39. header: {
  40. Accept: "text/json",
  41. "Content-Type": "application/json;charset=UTF-8",
  42. platform: sheep_platform_index._platform.name
  43. },
  44. custom: options
  45. });
  46. http.interceptors.request.use(
  47. (config) => {
  48. if (config.custom.auth && !sheep_store_index.$store("user").isLogin) {
  49. sheep_hooks_useModal.showAuthModal();
  50. return Promise.reject();
  51. }
  52. if (config.custom.showLoading) {
  53. LoadingInstance.count++;
  54. LoadingInstance.count === 1 && common_vendor.index.showLoading({
  55. title: config.custom.loadingMsg,
  56. mask: true,
  57. fail: () => {
  58. common_vendor.index.hideLoading();
  59. }
  60. });
  61. }
  62. const token = getAccessToken();
  63. if (token) {
  64. config.header["Authorization"] = token;
  65. }
  66. config.header["Accept"] = "*/*";
  67. config.header["tenant-id"] = "1";
  68. config.header["terminal"] = "20";
  69. return config;
  70. },
  71. (error) => {
  72. return Promise.reject(error);
  73. }
  74. );
  75. http.interceptors.response.use(
  76. (response) => {
  77. var _a, _b;
  78. if (response.config.url.indexOf("/member/auth/") >= 0 && ((_b = (_a = response.data) == null ? void 0 : _a.data) == null ? void 0 : _b.accessToken)) {
  79. sheep_store_index.$store("user").setToken(response.data.data.accessToken, response.data.data.refreshToken);
  80. }
  81. response.config.custom.showLoading && closeLoading();
  82. if (response.data.code !== 0) {
  83. if (response.data.code === 401) {
  84. sheep_hooks_useModal.cancelAutoSign();
  85. return refreshToken(response.config);
  86. }
  87. if (response.config.custom.showError) {
  88. sheep_hooks_useModal.cancelAutoSign();
  89. common_vendor.index.showToast({
  90. title: response.data.msg || "服务器开小差啦,请稍后再试~",
  91. icon: "none",
  92. mask: true
  93. });
  94. }
  95. }
  96. if (response.config.custom.showSuccess && response.config.custom.successMsg !== "" && response.data.code === 0) {
  97. common_vendor.index.showToast({
  98. title: response.config.custom.successMsg,
  99. icon: "none"
  100. });
  101. }
  102. return Promise.resolve(response.data);
  103. },
  104. (error) => {
  105. var _a;
  106. console.log("服务器开小差");
  107. sheep_hooks_useModal.cancelAutoSign();
  108. const userStore = sheep_store_index.$store("user");
  109. const isLogin = userStore.isLogin;
  110. let errorMessage = "网络请求出错";
  111. if (error !== void 0) {
  112. switch (error.statusCode) {
  113. case 400:
  114. errorMessage = "请求错误";
  115. break;
  116. case 401:
  117. errorMessage = isLogin ? "您的登陆已过期" : "请登录";
  118. break;
  119. case 403:
  120. errorMessage = "拒绝访问";
  121. break;
  122. case 404:
  123. errorMessage = "请求出错";
  124. break;
  125. case 408:
  126. errorMessage = "请求超时";
  127. break;
  128. case 429:
  129. errorMessage = "请求频繁, 请稍后再访问";
  130. break;
  131. case 500:
  132. errorMessage = "服务器开小差啦,请稍后再试~";
  133. break;
  134. case 501:
  135. errorMessage = "服务未实现";
  136. break;
  137. case 502:
  138. errorMessage = "网络错误";
  139. break;
  140. case 503:
  141. errorMessage = "服务不可用";
  142. break;
  143. case 504:
  144. errorMessage = "网络超时";
  145. break;
  146. case 505:
  147. errorMessage = "HTTP 版本不受支持";
  148. break;
  149. }
  150. if (error.errMsg.includes("timeout"))
  151. errorMessage = "请求超时";
  152. }
  153. if (error && error.config) {
  154. if (error.config.custom.showError === false) {
  155. common_vendor.index.showToast({
  156. title: ((_a = error.data) == null ? void 0 : _a.msg) || errorMessage,
  157. icon: "none",
  158. mask: true
  159. });
  160. }
  161. error.config.custom.showLoading && closeLoading();
  162. }
  163. return false;
  164. }
  165. );
  166. let requestList = [];
  167. let isRefreshToken = false;
  168. const refreshToken = async (config) => {
  169. if (config.url.indexOf("/member/auth/refresh-token") >= 0) {
  170. return Promise.reject("error");
  171. }
  172. if (!isRefreshToken) {
  173. isRefreshToken = true;
  174. const refreshToken2 = getRefreshToken();
  175. if (!refreshToken2) {
  176. return handleAuthorized();
  177. }
  178. try {
  179. const refreshTokenResult = await sheep_api_member_auth.AuthUtil.refreshToken(refreshToken2);
  180. if (refreshTokenResult.code !== 0) {
  181. throw new Error("刷新令牌失败");
  182. }
  183. config.header.Authorization = "Bearer " + getAccessToken();
  184. requestList.forEach((cb) => {
  185. cb();
  186. });
  187. requestList = [];
  188. return request(config);
  189. } catch (e) {
  190. requestList.forEach((cb) => {
  191. cb();
  192. });
  193. return handleAuthorized();
  194. } finally {
  195. requestList = [];
  196. isRefreshToken = false;
  197. }
  198. } else {
  199. return new Promise((resolve) => {
  200. requestList.push(() => {
  201. config.header.Authorization = "Bearer " + getAccessToken();
  202. resolve(request(config));
  203. });
  204. });
  205. }
  206. };
  207. const handleAuthorized = () => {
  208. const userStore = sheep_store_index.$store("user");
  209. userStore.logout(true);
  210. sheep_hooks_useModal.showAuthModal();
  211. return Promise.reject({
  212. code: 401,
  213. msg: userStore.isLogin ? "您的登陆已过期" : "请登录"
  214. });
  215. };
  216. const getAccessToken = () => {
  217. return common_vendor.index.getStorageSync("token");
  218. };
  219. const getRefreshToken = () => {
  220. return common_vendor.index.getStorageSync("refresh-token");
  221. };
  222. const request = (config) => {
  223. return http.middleware(config);
  224. };
  225. const request$1 = request;
  226. exports.request = request$1;