index.js 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222
  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. return refreshToken(response.config);
  85. }
  86. if (response.config.custom.showError) {
  87. common_vendor.index.showToast({
  88. title: response.data.msg || "服务器开小差啦,请稍后再试~",
  89. icon: "none",
  90. mask: true
  91. });
  92. }
  93. }
  94. if (response.config.custom.showSuccess && response.config.custom.successMsg !== "" && response.data.code === 0) {
  95. common_vendor.index.showToast({
  96. title: response.config.custom.successMsg,
  97. icon: "none"
  98. });
  99. }
  100. return Promise.resolve(response.data);
  101. },
  102. (error) => {
  103. var _a;
  104. const userStore = sheep_store_index.$store("user");
  105. const isLogin = userStore.isLogin;
  106. let errorMessage = "网络请求出错";
  107. if (error !== void 0) {
  108. switch (error.statusCode) {
  109. case 400:
  110. errorMessage = "请求错误";
  111. break;
  112. case 401:
  113. errorMessage = isLogin ? "您的登陆已过期" : "请先登录";
  114. break;
  115. case 403:
  116. errorMessage = "拒绝访问";
  117. break;
  118. case 404:
  119. errorMessage = "请求出错";
  120. break;
  121. case 408:
  122. errorMessage = "请求超时";
  123. break;
  124. case 429:
  125. errorMessage = "请求频繁, 请稍后再访问";
  126. break;
  127. case 500:
  128. errorMessage = "服务器开小差啦,请稍后再试~";
  129. break;
  130. case 501:
  131. errorMessage = "服务未实现";
  132. break;
  133. case 502:
  134. errorMessage = "网络错误";
  135. break;
  136. case 503:
  137. errorMessage = "服务不可用";
  138. break;
  139. case 504:
  140. errorMessage = "网络超时";
  141. break;
  142. case 505:
  143. errorMessage = "HTTP 版本不受支持";
  144. break;
  145. }
  146. if (error.errMsg.includes("timeout"))
  147. errorMessage = "请求超时";
  148. }
  149. if (error && error.config) {
  150. if (error.config.custom.showError === false) {
  151. common_vendor.index.showToast({
  152. title: ((_a = error.data) == null ? void 0 : _a.msg) || errorMessage,
  153. icon: "none",
  154. mask: true
  155. });
  156. }
  157. error.config.custom.showLoading && closeLoading();
  158. }
  159. return false;
  160. }
  161. );
  162. let requestList = [];
  163. let isRefreshToken = false;
  164. const refreshToken = async (config) => {
  165. if (config.url.indexOf("/member/auth/refresh-token") >= 0) {
  166. return Promise.reject("error");
  167. }
  168. if (!isRefreshToken) {
  169. isRefreshToken = true;
  170. const refreshToken2 = getRefreshToken();
  171. if (!refreshToken2) {
  172. return handleAuthorized();
  173. }
  174. try {
  175. const refreshTokenResult = await sheep_api_member_auth.AuthUtil.refreshToken(refreshToken2);
  176. if (refreshTokenResult.code !== 0) {
  177. throw new Error("刷新令牌失败");
  178. }
  179. config.header.Authorization = "Bearer " + getAccessToken();
  180. requestList.forEach((cb) => {
  181. cb();
  182. });
  183. requestList = [];
  184. return request(config);
  185. } catch (e) {
  186. requestList.forEach((cb) => {
  187. cb();
  188. });
  189. return handleAuthorized();
  190. } finally {
  191. requestList = [];
  192. isRefreshToken = false;
  193. }
  194. } else {
  195. return new Promise((resolve) => {
  196. requestList.push(() => {
  197. config.header.Authorization = "Bearer " + getAccessToken();
  198. resolve(request(config));
  199. });
  200. });
  201. }
  202. };
  203. const handleAuthorized = () => {
  204. const userStore = sheep_store_index.$store("user");
  205. userStore.logout(true);
  206. sheep_hooks_useModal.showAuthModal();
  207. return Promise.reject({
  208. code: 401,
  209. msg: userStore.isLogin ? "您的登陆已过期" : "请先登录"
  210. });
  211. };
  212. const getAccessToken = () => {
  213. return common_vendor.index.getStorageSync("token");
  214. };
  215. const getRefreshToken = () => {
  216. return common_vendor.index.getStorageSync("refresh-token");
  217. };
  218. const request = (config) => {
  219. return http.middleware(config);
  220. };
  221. const request$1 = request;
  222. exports.request = request$1;