@vlian/framework 1.2.25 → 1.2.38

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (319) hide show
  1. package/dist/analytics.umd.js +208 -2395
  2. package/dist/analytics.umd.js.map +1 -1
  3. package/dist/core/Test.cjs +2 -2
  4. package/dist/core/Test.cjs.map +1 -1
  5. package/dist/core/Test.js +1 -1
  6. package/dist/core/Test.js.map +1 -1
  7. package/dist/core/config/ConfigLoader.cjs +7 -7
  8. package/dist/core/config/ConfigLoader.cjs.map +1 -1
  9. package/dist/core/config/ConfigLoader.js +1 -1
  10. package/dist/core/config/ConfigLoader.js.map +1 -1
  11. package/dist/core/error/ErrorBoundary.cjs +6 -6
  12. package/dist/core/error/ErrorBoundary.cjs.map +1 -1
  13. package/dist/core/error/ErrorBoundary.d.ts +1 -1
  14. package/dist/core/error/ErrorBoundary.js +2 -2
  15. package/dist/core/error/ErrorBoundary.js.map +1 -1
  16. package/dist/core/error/ErrorHandler.cjs +19 -19
  17. package/dist/core/error/ErrorHandler.cjs.map +1 -1
  18. package/dist/core/error/ErrorHandler.d.ts +2 -2
  19. package/dist/core/error/ErrorHandler.js +2 -2
  20. package/dist/core/error/ErrorHandler.js.map +1 -1
  21. package/dist/core/event/AppEventBus.cjs +5 -5
  22. package/dist/core/event/AppEventBus.cjs.map +1 -1
  23. package/dist/core/event/AppEventBus.js +1 -1
  24. package/dist/core/event/AppEventBus.js.map +1 -1
  25. package/dist/core/initialization/InitializationErrorThrower.cjs.map +1 -1
  26. package/dist/core/initialization/InitializationErrorThrower.js.map +1 -1
  27. package/dist/core/initialization/initialization.cjs +3 -3
  28. package/dist/core/initialization/initialization.cjs.map +1 -1
  29. package/dist/core/initialization/initialization.d.ts +1 -1
  30. package/dist/core/initialization/initialization.js +1 -1
  31. package/dist/core/initialization/initialization.js.map +1 -1
  32. package/dist/core/initialization/initializationErrorState.cjs +2 -2
  33. package/dist/core/initialization/initializationErrorState.cjs.map +1 -1
  34. package/dist/core/initialization/initializationErrorState.d.ts +1 -1
  35. package/dist/core/initialization/initializationErrorState.js +1 -1
  36. package/dist/core/initialization/initializationErrorState.js.map +1 -1
  37. package/dist/core/kernel/defaultAdapters.cjs +14 -13
  38. package/dist/core/kernel/defaultAdapters.cjs.map +1 -1
  39. package/dist/core/kernel/defaultAdapters.js +2 -1
  40. package/dist/core/kernel/defaultAdapters.js.map +1 -1
  41. package/dist/core/kernel/types.d.ts +1 -1
  42. package/dist/core/kernel/types.js.map +1 -1
  43. package/dist/core/router/RouterManager.cjs +9 -9
  44. package/dist/core/router/RouterManager.cjs.map +1 -1
  45. package/dist/core/router/RouterManager.js +1 -1
  46. package/dist/core/router/RouterManager.js.map +1 -1
  47. package/dist/core/router/adapter/AdapterManager.cjs +10 -10
  48. package/dist/core/router/adapter/AdapterManager.cjs.map +1 -1
  49. package/dist/core/router/adapter/AdapterManager.js +1 -1
  50. package/dist/core/router/adapter/AdapterManager.js.map +1 -1
  51. package/dist/core/router/adapter/react-router/ReactRouterAdapter.cjs +4 -4
  52. package/dist/core/router/adapter/react-router/ReactRouterAdapter.cjs.map +1 -1
  53. package/dist/core/router/adapter/react-router/ReactRouterAdapter.js +1 -1
  54. package/dist/core/router/adapter/react-router/ReactRouterAdapter.js.map +1 -1
  55. package/dist/core/router/dynamic/DynamicRouteManager.cjs +8 -8
  56. package/dist/core/router/dynamic/DynamicRouteManager.cjs.map +1 -1
  57. package/dist/core/router/dynamic/DynamicRouteManager.js +1 -1
  58. package/dist/core/router/dynamic/DynamicRouteManager.js.map +1 -1
  59. package/dist/core/router/errors/RouterError.cjs +4 -4
  60. package/dist/core/router/errors/RouterError.cjs.map +1 -1
  61. package/dist/core/router/errors/RouterError.d.ts +1 -1
  62. package/dist/core/router/errors/RouterError.js +1 -1
  63. package/dist/core/router/errors/RouterError.js.map +1 -1
  64. package/dist/core/router/lifecycle/RouterLifecycleManager.cjs +8 -8
  65. package/dist/core/router/lifecycle/RouterLifecycleManager.cjs.map +1 -1
  66. package/dist/core/router/lifecycle/RouterLifecycleManager.js +1 -1
  67. package/dist/core/router/lifecycle/RouterLifecycleManager.js.map +1 -1
  68. package/dist/core/router/middleware/RouterMiddlewareManager.cjs +11 -11
  69. package/dist/core/router/middleware/RouterMiddlewareManager.cjs.map +1 -1
  70. package/dist/core/router/middleware/RouterMiddlewareManager.js +1 -1
  71. package/dist/core/router/middleware/RouterMiddlewareManager.js.map +1 -1
  72. package/dist/core/router/middleware/auth.cjs +4 -4
  73. package/dist/core/router/middleware/auth.cjs.map +1 -1
  74. package/dist/core/router/middleware/auth.js +1 -1
  75. package/dist/core/router/middleware/auth.js.map +1 -1
  76. package/dist/core/router/monitoring/RouterMonitoring.cjs +2 -2
  77. package/dist/core/router/monitoring/RouterMonitoring.cjs.map +1 -1
  78. package/dist/core/router/monitoring/RouterMonitoring.js +2 -2
  79. package/dist/core/router/monitoring/RouterMonitoring.js.map +1 -1
  80. package/dist/core/router/navigation/RouterNavigation.cjs +7 -7
  81. package/dist/core/router/navigation/RouterNavigation.cjs.map +1 -1
  82. package/dist/core/router/navigation/RouterNavigation.js +1 -1
  83. package/dist/core/router/navigation/RouterNavigation.js.map +1 -1
  84. package/dist/core/router/performance/RouteCache.cjs +7 -7
  85. package/dist/core/router/performance/RouteCache.cjs.map +1 -1
  86. package/dist/core/router/performance/RouteCache.js +1 -1
  87. package/dist/core/router/performance/RouteCache.js.map +1 -1
  88. package/dist/core/router/performance/RoutePreloader.cjs +6 -6
  89. package/dist/core/router/performance/RoutePreloader.cjs.map +1 -1
  90. package/dist/core/router/performance/RoutePreloader.js +1 -1
  91. package/dist/core/router/performance/RoutePreloader.js.map +1 -1
  92. package/dist/core/router/plugin/RouterPluginManager.cjs +8 -8
  93. package/dist/core/router/plugin/RouterPluginManager.cjs.map +1 -1
  94. package/dist/core/router/plugin/RouterPluginManager.js +1 -1
  95. package/dist/core/router/plugin/RouterPluginManager.js.map +1 -1
  96. package/dist/core/router/utils/adapters/react-router/transform.cjs +6 -2
  97. package/dist/core/router/utils/adapters/react-router/transform.cjs.map +1 -1
  98. package/dist/core/router/utils/adapters/react-router/transform.js +5 -1
  99. package/dist/core/router/utils/adapters/react-router/transform.js.map +1 -1
  100. package/dist/core/router/utils/transform.cjs +13 -12
  101. package/dist/core/router/utils/transform.cjs.map +1 -1
  102. package/dist/core/router/utils/transform.js +2 -1
  103. package/dist/core/router/utils/transform.js.map +1 -1
  104. package/dist/core/router/validation/RouterConfigValidator.cjs +2 -2
  105. package/dist/core/router/validation/RouterConfigValidator.cjs.map +1 -1
  106. package/dist/core/router/validation/RouterConfigValidator.js +1 -1
  107. package/dist/core/router/validation/RouterConfigValidator.js.map +1 -1
  108. package/dist/core/router/version/RouteVersionManager.cjs +6 -6
  109. package/dist/core/router/version/RouteVersionManager.cjs.map +1 -1
  110. package/dist/core/router/version/RouteVersionManager.js +1 -1
  111. package/dist/core/router/version/RouteVersionManager.js.map +1 -1
  112. package/dist/core/splash/SplashScreen.cjs +4 -4
  113. package/dist/core/splash/SplashScreen.cjs.map +1 -1
  114. package/dist/core/splash/SplashScreen.js +1 -1
  115. package/dist/core/splash/SplashScreen.js.map +1 -1
  116. package/dist/core/startup/initializeServices.cjs +15 -15
  117. package/dist/core/startup/initializeServices.cjs.map +1 -1
  118. package/dist/core/startup/initializeServices.d.ts +2 -2
  119. package/dist/core/startup/initializeServices.js +3 -3
  120. package/dist/core/startup/initializeServices.js.map +1 -1
  121. package/dist/core/startup/performanceTracker.cjs.map +1 -1
  122. package/dist/core/startup/performanceTracker.d.ts +1 -1
  123. package/dist/core/startup/performanceTracker.js.map +1 -1
  124. package/dist/core/startup/renderApp.cjs +3 -3
  125. package/dist/core/startup/renderApp.cjs.map +1 -1
  126. package/dist/core/startup/renderApp.d.ts +1 -1
  127. package/dist/core/startup/renderApp.js +2 -2
  128. package/dist/core/startup/renderApp.js.map +1 -1
  129. package/dist/core/startup/startApp.cjs +24 -24
  130. package/dist/core/startup/startApp.cjs.map +1 -1
  131. package/dist/core/startup/startApp.js +5 -5
  132. package/dist/core/startup/startApp.js.map +1 -1
  133. package/dist/core/types.d.ts +3 -3
  134. package/dist/core/types.js.map +1 -1
  135. package/dist/index.cjs +15 -2
  136. package/dist/index.cjs.map +1 -1
  137. package/dist/index.d.ts +6 -4
  138. package/dist/index.js +5 -4
  139. package/dist/index.js.map +1 -1
  140. package/dist/index.umd.js +2150 -23125
  141. package/dist/index.umd.js.map +1 -1
  142. package/dist/kernel/constants.cjs +67 -0
  143. package/dist/kernel/constants.cjs.map +1 -0
  144. package/dist/kernel/constants.d.ts +5 -0
  145. package/dist/kernel/constants.js +43 -0
  146. package/dist/kernel/constants.js.map +1 -0
  147. package/dist/kernel/index.cjs +40 -0
  148. package/dist/kernel/index.cjs.map +1 -0
  149. package/dist/kernel/index.d.ts +3 -0
  150. package/dist/kernel/index.js +4 -0
  151. package/dist/kernel/index.js.map +1 -0
  152. package/dist/kernel/kernel.cjs +296 -0
  153. package/dist/kernel/kernel.cjs.map +1 -0
  154. package/dist/kernel/kernel.d.ts +40 -0
  155. package/dist/kernel/kernel.js +272 -0
  156. package/dist/kernel/kernel.js.map +1 -0
  157. package/dist/kernel/manager/cacheManager.cjs +46 -0
  158. package/dist/kernel/manager/cacheManager.cjs.map +1 -0
  159. package/dist/kernel/manager/cacheManager.d.ts +6 -0
  160. package/dist/kernel/manager/cacheManager.js +36 -0
  161. package/dist/kernel/manager/cacheManager.js.map +1 -0
  162. package/dist/kernel/manager/i18nManager.cjs +68 -0
  163. package/dist/kernel/manager/i18nManager.cjs.map +1 -0
  164. package/dist/kernel/manager/i18nManager.d.ts +8 -0
  165. package/dist/kernel/manager/i18nManager.js +58 -0
  166. package/dist/kernel/manager/i18nManager.js.map +1 -0
  167. package/dist/kernel/manager/index.cjs +30 -0
  168. package/dist/kernel/manager/index.cjs.map +1 -0
  169. package/dist/kernel/manager/index.d.ts +4 -0
  170. package/dist/kernel/manager/index.js +6 -0
  171. package/dist/kernel/manager/index.js.map +1 -0
  172. package/dist/kernel/manager/loggerManager.cjs +70 -0
  173. package/dist/kernel/manager/loggerManager.cjs.map +1 -0
  174. package/dist/kernel/manager/loggerManager.d.ts +14 -0
  175. package/dist/kernel/manager/loggerManager.js +60 -0
  176. package/dist/kernel/manager/loggerManager.js.map +1 -0
  177. package/dist/kernel/manager/persistence.cjs +93 -0
  178. package/dist/kernel/manager/persistence.cjs.map +1 -0
  179. package/dist/kernel/manager/persistence.d.ts +3 -0
  180. package/dist/kernel/manager/persistence.js +75 -0
  181. package/dist/kernel/manager/persistence.js.map +1 -0
  182. package/dist/kernel/manager/themeManager.cjs +85 -0
  183. package/dist/kernel/manager/themeManager.cjs.map +1 -0
  184. package/dist/kernel/manager/themeManager.d.ts +9 -0
  185. package/dist/kernel/manager/themeManager.js +75 -0
  186. package/dist/kernel/manager/themeManager.js.map +1 -0
  187. package/dist/kernel/types.cjs +6 -0
  188. package/dist/kernel/types.cjs.map +1 -0
  189. package/dist/kernel/types.d.ts +72 -0
  190. package/dist/kernel/types.js +3 -0
  191. package/dist/kernel/types.js.map +1 -0
  192. package/dist/library/storage/encryption.cjs +12 -13
  193. package/dist/library/storage/encryption.cjs.map +1 -1
  194. package/dist/library/storage/encryption.js +1 -2
  195. package/dist/library/storage/encryption.js.map +1 -1
  196. package/dist/request/adapter.d.ts +1 -0
  197. package/dist/request/core.d.ts +1 -0
  198. package/dist/request/index.d.ts +1 -42
  199. package/dist/request/plugin/csrfPlugin.d.ts +2 -2
  200. package/dist/request/plugin/queue.d.ts +2 -2
  201. package/dist/request/plugin.d.ts +1 -0
  202. package/dist/request/runtime.d.ts +1 -0
  203. package/dist/request/types.d.ts +1 -394
  204. package/dist/request/utils.d.ts +1 -0
  205. package/dist/state.umd.js +1 -1
  206. package/dist/utils/csrf.cjs +13 -152
  207. package/dist/utils/csrf.cjs.map +1 -1
  208. package/dist/utils/csrf.d.ts +1 -72
  209. package/dist/utils/csrf.js +1 -142
  210. package/dist/utils/csrf.js.map +1 -1
  211. package/dist/utils/errors/ErrorCodes.cjs +6 -76
  212. package/dist/utils/errors/ErrorCodes.cjs.map +1 -1
  213. package/dist/utils/errors/ErrorCodes.d.ts +1 -45
  214. package/dist/utils/errors/ErrorCodes.js +1 -84
  215. package/dist/utils/errors/ErrorCodes.js.map +1 -1
  216. package/dist/utils/errors.cjs +53 -326
  217. package/dist/utils/errors.cjs.map +1 -1
  218. package/dist/utils/errors.d.ts +19 -172
  219. package/dist/utils/errors.js +16 -352
  220. package/dist/utils/errors.js.map +1 -1
  221. package/dist/utils/logger.cjs +5 -374
  222. package/dist/utils/logger.cjs.map +1 -1
  223. package/dist/utils/logger.d.ts +2 -189
  224. package/dist/utils/logger.js +1 -379
  225. package/dist/utils/logger.js.map +1 -1
  226. package/dist/utils/logger.types.cjs +3 -12
  227. package/dist/utils/logger.types.cjs.map +1 -1
  228. package/dist/utils/logger.types.d.ts +2 -57
  229. package/dist/utils/logger.types.js +1 -10
  230. package/dist/utils/logger.types.js.map +1 -1
  231. package/dist/utils/monitoring.cjs +11 -302
  232. package/dist/utils/monitoring.cjs.map +1 -1
  233. package/dist/utils/monitoring.d.ts +1 -163
  234. package/dist/utils/monitoring.js +1 -294
  235. package/dist/utils/monitoring.js.map +1 -1
  236. package/dist/utils/performance.cjs +5 -352
  237. package/dist/utils/performance.cjs.map +1 -1
  238. package/dist/utils/performance.d.ts +2 -246
  239. package/dist/utils/performance.js +1 -354
  240. package/dist/utils/performance.js.map +1 -1
  241. package/dist/utils/resourceLoader.cjs +5 -303
  242. package/dist/utils/resourceLoader.cjs.map +1 -1
  243. package/dist/utils/resourceLoader.d.ts +2 -130
  244. package/dist/utils/resourceLoader.js +1 -305
  245. package/dist/utils/resourceLoader.js.map +1 -1
  246. package/dist/utils/runtimeSecurity.cjs +2 -140
  247. package/dist/utils/runtimeSecurity.cjs.map +1 -1
  248. package/dist/utils/runtimeSecurity.d.ts +2 -104
  249. package/dist/utils/runtimeSecurity.js +1 -141
  250. package/dist/utils/runtimeSecurity.js.map +1 -1
  251. package/dist/utils/security.cjs +3 -314
  252. package/dist/utils/security.cjs.map +1 -1
  253. package/dist/utils/security.d.ts +2 -80
  254. package/dist/utils/security.js +1 -311
  255. package/dist/utils/security.js.map +1 -1
  256. package/dist/utils/traceId.cjs +10 -111
  257. package/dist/utils/traceId.cjs.map +1 -1
  258. package/dist/utils/traceId.d.ts +1 -63
  259. package/dist/utils/traceId.js +1 -116
  260. package/dist/utils/traceId.js.map +1 -1
  261. package/dist/utils/validation.cjs +3 -173
  262. package/dist/utils/validation.cjs.map +1 -1
  263. package/dist/utils/validation.d.ts +2 -110
  264. package/dist/utils/validation.js +1 -175
  265. package/dist/utils/validation.js.map +1 -1
  266. package/package.json +15 -24
  267. package/dist/lazy/index.cjs +0 -104
  268. package/dist/lazy/index.cjs.map +0 -1
  269. package/dist/lazy/index.d.ts +0 -19
  270. package/dist/lazy/index.js +0 -24
  271. package/dist/lazy/index.js.map +0 -1
  272. package/dist/request/adapter/RequestAdapter.cjs +0 -78
  273. package/dist/request/adapter/RequestAdapter.cjs.map +0 -1
  274. package/dist/request/adapter/axiosAdapter.cjs +0 -164
  275. package/dist/request/adapter/axiosAdapter.cjs.map +0 -1
  276. package/dist/request/adapter/fetchAdapter.cjs +0 -134
  277. package/dist/request/adapter/fetchAdapter.cjs.map +0 -1
  278. package/dist/request/adapter/index.cjs +0 -80
  279. package/dist/request/adapter/index.cjs.map +0 -1
  280. package/dist/request/adapter/kyAdapter.cjs +0 -191
  281. package/dist/request/adapter/kyAdapter.cjs.map +0 -1
  282. package/dist/request/adapter/undiciAdapter.cjs +0 -213
  283. package/dist/request/adapter/undiciAdapter.cjs.map +0 -1
  284. package/dist/request/core/RequestClient.cjs +0 -558
  285. package/dist/request/core/RequestClient.cjs.map +0 -1
  286. package/dist/request/core/index.cjs +0 -15
  287. package/dist/request/core/index.cjs.map +0 -1
  288. package/dist/request/index.cjs +0 -149
  289. package/dist/request/index.cjs.map +0 -1
  290. package/dist/request/plugin/RequestPlugin.cjs +0 -218
  291. package/dist/request/plugin/RequestPlugin.cjs.map +0 -1
  292. package/dist/request/plugin/cache.cjs +0 -269
  293. package/dist/request/plugin/cache.cjs.map +0 -1
  294. package/dist/request/plugin/csrfPlugin.cjs +0 -40
  295. package/dist/request/plugin/csrfPlugin.cjs.map +0 -1
  296. package/dist/request/plugin/index.cjs +0 -53
  297. package/dist/request/plugin/index.cjs.map +0 -1
  298. package/dist/request/plugin/monitoring.cjs +0 -216
  299. package/dist/request/plugin/monitoring.cjs.map +0 -1
  300. package/dist/request/plugin/queue.cjs +0 -140
  301. package/dist/request/plugin/queue.cjs.map +0 -1
  302. package/dist/request/plugin/retry.cjs +0 -98
  303. package/dist/request/plugin/retry.cjs.map +0 -1
  304. package/dist/request/plugin/validation.cjs +0 -121
  305. package/dist/request/plugin/validation.cjs.map +0 -1
  306. package/dist/request/runtime/RequestContext.cjs +0 -77
  307. package/dist/request/runtime/RequestContext.cjs.map +0 -1
  308. package/dist/request/runtime/index.cjs +0 -32
  309. package/dist/request/runtime/index.cjs.map +0 -1
  310. package/dist/request/types.cjs +0 -112
  311. package/dist/request/types.cjs.map +0 -1
  312. package/dist/request/utils/RequestQueueManager.cjs +0 -168
  313. package/dist/request/utils/RequestQueueManager.cjs.map +0 -1
  314. package/dist/request/utils/dependencyCheck.cjs +0 -237
  315. package/dist/request/utils/dependencyCheck.cjs.map +0 -1
  316. package/dist/request/utils/index.cjs +0 -30
  317. package/dist/request/utils/index.cjs.map +0 -1
  318. package/dist/request.umd.js +0 -5392
  319. package/dist/request.umd.js.map +0 -1
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../src/request/plugin/cache.ts"],"sourcesContent":["/**\n * 缓存插件\n * \n * 提供请求缓存能力,支持内存、localStorage、sessionStorage 存储\n */\n\nimport type { RequestPlugin } from './RequestPlugin';\nimport type { RequestOptions, Response, RequestContext, CacheConfig } from '../types';\nimport { PluginPriority } from './RequestPlugin';\nimport { logger } from '../../utils/logger';\n\n/**\n * 缓存存储接口\n */\ninterface CacheStorage {\n get(key: string): Promise<Response | null>;\n set(key: string, value: Response, ttl: number): Promise<void>;\n delete(key: string): Promise<void>;\n clear(): Promise<void>;\n}\n\n/**\n * 内存缓存存储实现\n */\nclass MemoryCacheStorage implements CacheStorage {\n private cache = new Map<string, { value: Response; expires: number }>();\n\n async get(key: string): Promise<Response | null> {\n const item = this.cache.get(key);\n if (!item) {\n return null;\n }\n\n if (Date.now() > item.expires) {\n this.cache.delete(key);\n return null;\n }\n\n return item.value;\n }\n\n async set(key: string, value: Response, ttl: number): Promise<void> {\n const expires = Date.now() + ttl;\n this.cache.set(key, { value, expires });\n }\n\n async delete(key: string): Promise<void> {\n this.cache.delete(key);\n }\n\n async clear(): Promise<void> {\n this.cache.clear();\n }\n}\n\n/**\n * LocalStorage 缓存存储实现\n */\nclass LocalStorageCacheStorage implements CacheStorage {\n private prefix = 'request_cache_';\n\n async get(key: string): Promise<Response | null> {\n if (typeof localStorage === 'undefined') {\n return null;\n }\n\n try {\n const item = localStorage.getItem(this.prefix + key);\n if (!item) {\n return null;\n }\n\n const { value, expires } = JSON.parse(item);\n if (Date.now() > expires) {\n localStorage.removeItem(this.prefix + key);\n return null;\n }\n\n return value as Response;\n } catch {\n return null;\n }\n }\n\n async set(key: string, value: Response, ttl: number): Promise<void> {\n if (typeof localStorage === 'undefined') {\n return;\n }\n\n try {\n const expires = Date.now() + ttl;\n localStorage.setItem(this.prefix + key, JSON.stringify({ value, expires }));\n } catch (error) {\n // 存储失败(可能是存储空间不足)\n logger.warn('缓存存储失败:', error);\n }\n }\n\n async delete(key: string): Promise<void> {\n if (typeof localStorage === 'undefined') {\n return;\n }\n\n localStorage.removeItem(this.prefix + key);\n }\n\n async clear(): Promise<void> {\n if (typeof localStorage === 'undefined') {\n return;\n }\n\n const keys = Object.keys(localStorage);\n for (const key of keys) {\n if (key.startsWith(this.prefix)) {\n localStorage.removeItem(key);\n }\n }\n }\n}\n\n/**\n * SessionStorage 缓存存储实现\n */\nclass SessionStorageCacheStorage implements CacheStorage {\n private prefix = 'request_cache_';\n\n async get(key: string): Promise<Response | null> {\n if (typeof sessionStorage === 'undefined') {\n return null;\n }\n\n try {\n const item = sessionStorage.getItem(this.prefix + key);\n if (!item) {\n return null;\n }\n\n const { value, expires } = JSON.parse(item);\n if (Date.now() > expires) {\n sessionStorage.removeItem(this.prefix + key);\n return null;\n }\n\n return value as Response;\n } catch {\n return null;\n }\n }\n\n async set(key: string, value: Response, ttl: number): Promise<void> {\n if (typeof sessionStorage === 'undefined') {\n return;\n }\n\n try {\n const expires = Date.now() + ttl;\n sessionStorage.setItem(this.prefix + key, JSON.stringify({ value, expires }));\n } catch (error) {\n logger.warn('缓存存储失败:', error);\n }\n }\n\n async delete(key: string): Promise<void> {\n if (typeof sessionStorage === 'undefined') {\n return;\n }\n\n sessionStorage.removeItem(this.prefix + key);\n }\n\n async clear(): Promise<void> {\n if (typeof sessionStorage === 'undefined') {\n return;\n }\n\n const keys = Object.keys(sessionStorage);\n for (const key of keys) {\n if (key.startsWith(this.prefix)) {\n sessionStorage.removeItem(key);\n }\n }\n }\n}\n\n/**\n * 获取缓存存储实例\n */\nfunction getCacheStorage(storage: CacheConfig['storage'] = 'memory'): CacheStorage {\n switch (storage) {\n case 'localStorage':\n return new LocalStorageCacheStorage();\n case 'sessionStorage':\n return new SessionStorageCacheStorage();\n case 'memory':\n default:\n return new MemoryCacheStorage();\n }\n}\n\n/**\n * 生成缓存键\n */\nfunction generateCacheKey(request: RequestOptions): string {\n const { url, method = 'GET', query, body } = request;\n const cacheKey = request.cache?.key || `${method}:${url}`;\n\n // 包含查询参数和请求体(如果存在)\n const keyParts = [cacheKey];\n if (query) {\n keyParts.push(JSON.stringify(query));\n }\n if (body && typeof body === 'object') {\n keyParts.push(JSON.stringify(body));\n }\n\n return keyParts.join('|');\n}\n\n/**\n * 缓存插件配置\n */\nexport interface CachePluginConfig {\n /**\n * 默认缓存时间(毫秒)\n */\n defaultTTL?: number;\n\n /**\n * 默认存储类型\n */\n defaultStorage?: CacheConfig['storage'];\n\n /**\n * 是否启用缓存\n */\n enabled?: boolean;\n}\n\n/**\n * 创建缓存插件\n * \n * @param config - 缓存插件配置\n * @returns 缓存插件实例\n */\nexport function createCachePlugin(config: CachePluginConfig = {}): RequestPlugin<{ hit?: boolean }> {\n const {\n defaultTTL = 5 * 60 * 1000, // 默认 5 分钟\n defaultStorage = 'memory',\n enabled = true,\n } = config;\n\n return {\n name: 'cache',\n priority: PluginPriority.LOWEST, // 最低优先级,最后执行\n\n async onBeforeRequest(context: RequestContext): Promise<RequestOptions | void> {\n if (!enabled) {\n return;\n }\n\n const cacheConfig = context.request.cache;\n if (!cacheConfig) {\n // 如果没有配置缓存,跳过\n return;\n }\n\n // 如果强制刷新,跳过缓存\n if (cacheConfig.forceRefresh) {\n return;\n }\n\n // 只缓存 GET 请求\n if (context.request.method && context.request.method !== 'GET') {\n return;\n }\n\n const storage = getCacheStorage(cacheConfig.storage || defaultStorage);\n const cacheKey = generateCacheKey(context.request);\n\n // 尝试从缓存获取\n const cachedResponse = await storage.get(cacheKey);\n if (cachedResponse) {\n // 缓存命中,标记并设置缓存的响应\n context.meta.hit = true;\n context.response = cachedResponse;\n // 标记请求已取消,避免实际发送请求\n context.cancelled = true;\n return;\n }\n\n // 缓存未命中\n context.meta.hit = false;\n },\n\n async onAfterRequest(context: RequestContext): Promise<Response | void> {\n if (!enabled || !context.response) {\n return;\n }\n\n const cacheConfig = context.request.cache;\n if (!cacheConfig) {\n return;\n }\n\n // 检查是否应该缓存\n const shouldCache = cacheConfig.shouldCache\n ? cacheConfig.shouldCache(context.response)\n : context.response.status >= 200 && context.response.status < 300;\n\n if (!shouldCache) {\n return;\n }\n\n // 只缓存 GET 请求\n if (context.request.method && context.request.method !== 'GET') {\n return;\n }\n\n const storage = getCacheStorage(cacheConfig.storage || defaultStorage);\n const cacheKey = generateCacheKey(context.request);\n const ttl = cacheConfig.ttl || defaultTTL;\n\n // 存储到缓存\n await storage.set(cacheKey, context.response, ttl);\n },\n };\n}\n"],"names":["createCachePlugin","MemoryCacheStorage","get","key","item","cache","Date","now","expires","delete","value","set","ttl","clear","Map","LocalStorageCacheStorage","localStorage","getItem","prefix","JSON","parse","removeItem","setItem","stringify","error","logger","warn","keys","Object","startsWith","SessionStorageCacheStorage","sessionStorage","getCacheStorage","storage","generateCacheKey","request","url","method","query","body","cacheKey","keyParts","push","join","config","defaultTTL","defaultStorage","enabled","name","priority","PluginPriority","LOWEST","onBeforeRequest","context","cacheConfig","forceRefresh","cachedResponse","meta","hit","response","cancelled","onAfterRequest","shouldCache","status"],"mappings":"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"}
@@ -1,40 +0,0 @@
1
- /**
2
- * CSRF 防护插件
3
- * 自动为请求添加 CSRF Token
4
- */ "use strict";
5
- Object.defineProperty(exports, "__esModule", {
6
- value: true
7
- });
8
- Object.defineProperty(exports, "createCSRFPlugin", {
9
- enumerable: true,
10
- get: function() {
11
- return createCSRFPlugin;
12
- }
13
- });
14
- const _RequestPlugin = require("./RequestPlugin");
15
- const _csrf = require("../../utils/csrf");
16
- function createCSRFPlugin() {
17
- return {
18
- name: 'csrf-protection',
19
- priority: _RequestPlugin.PluginPriority.HIGH,
20
- async onBeforeRequest (context) {
21
- const csrfManager = (0, _csrf.getCSRFManager)();
22
- if (!csrfManager) {
23
- // CSRF 管理器未初始化,跳过
24
- return;
25
- }
26
- // 获取 CSRF Token
27
- const token = await csrfManager.getToken();
28
- if (token) {
29
- // 添加 CSRF Token 到请求头
30
- const headerName = csrfManager.getHeaderName();
31
- context.request.headers = {
32
- ...context.request.headers,
33
- [headerName]: token
34
- };
35
- }
36
- }
37
- };
38
- }
39
-
40
- //# sourceMappingURL=csrfPlugin.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../src/request/plugin/csrfPlugin.ts"],"sourcesContent":["/**\n * CSRF 防护插件\n * 自动为请求添加 CSRF Token\n */\n\nimport type { RequestPlugin } from './RequestPlugin';\nimport { PluginPriority } from './RequestPlugin';\nimport { getCSRFManager } from '../../utils/csrf';\n\n/**\n * 创建 CSRF 防护插件\n * \n * @example\n * ```typescript\n * import { createRequestClient } from '@vlian/framework/request';\n * import { createCSRFPlugin } from '@vlian/framework/request/plugin';\n * \n * const client = await createRequestClient({\n * plugins: [\n * createCSRFPlugin(),\n * ],\n * });\n * ```\n */\nexport function createCSRFPlugin(): RequestPlugin {\n return {\n name: 'csrf-protection',\n priority: PluginPriority.HIGH, // 高优先级,确保在其他插件之前执行\n\n async onBeforeRequest(context) {\n const csrfManager = getCSRFManager();\n \n if (!csrfManager) {\n // CSRF 管理器未初始化,跳过\n return;\n }\n\n // 获取 CSRF Token\n const token = await csrfManager.getToken();\n \n if (token) {\n // 添加 CSRF Token 到请求头\n const headerName = csrfManager.getHeaderName();\n context.request.headers = {\n ...context.request.headers,\n [headerName]: token,\n };\n }\n },\n };\n}\n"],"names":["createCSRFPlugin","name","priority","PluginPriority","HIGH","onBeforeRequest","context","csrfManager","getCSRFManager","token","getToken","headerName","getHeaderName","request","headers"],"mappings":"AAAA;;;CAGC;;;;+BAqBeA;;;eAAAA;;;+BAlBe;sBACA;AAiBxB,SAASA;IACd,OAAO;QACLC,MAAM;QACNC,UAAUC,6BAAc,CAACC,IAAI;QAE7B,MAAMC,iBAAgBC,OAAO;YAC3B,MAAMC,cAAcC,IAAAA,oBAAc;YAElC,IAAI,CAACD,aAAa;gBAChB,kBAAkB;gBAClB;YACF;YAEA,gBAAgB;YAChB,MAAME,QAAQ,MAAMF,YAAYG,QAAQ;YAExC,IAAID,OAAO;gBACT,qBAAqB;gBACrB,MAAME,aAAaJ,YAAYK,aAAa;gBAC5CN,QAAQO,OAAO,CAACC,OAAO,GAAG;oBACxB,GAAGR,QAAQO,OAAO,CAACC,OAAO;oBAC1B,CAACH,WAAW,EAAEF;gBAChB;YACF;QACF;IACF;AACF"}
@@ -1,53 +0,0 @@
1
- /**
2
- * 插件模块导出
3
- */ "use strict";
4
- Object.defineProperty(exports, "__esModule", {
5
- value: true
6
- });
7
- function _export(target, all) {
8
- for(var name in all)Object.defineProperty(target, name, {
9
- enumerable: true,
10
- get: Object.getOwnPropertyDescriptor(all, name).get
11
- });
12
- }
13
- _export(exports, {
14
- get MonitoringEventType () {
15
- return _monitoring.MonitoringEventType;
16
- },
17
- get PluginLifecycleStage () {
18
- return _RequestPlugin.PluginLifecycleStage;
19
- },
20
- get PluginManager () {
21
- return _RequestPlugin.PluginManager;
22
- },
23
- get PluginPriority () {
24
- return _RequestPlugin.PluginPriority;
25
- },
26
- get createCSRFPlugin () {
27
- return _csrfPlugin.createCSRFPlugin;
28
- },
29
- get createCachePlugin () {
30
- return _cache.createCachePlugin;
31
- },
32
- get createMonitoringPlugin () {
33
- return _monitoring.createMonitoringPlugin;
34
- },
35
- get createQueuePlugin () {
36
- return _queue.createQueuePlugin;
37
- },
38
- get createRetryPlugin () {
39
- return _retry.createRetryPlugin;
40
- },
41
- get createValidationPlugin () {
42
- return _validation.createValidationPlugin;
43
- }
44
- });
45
- const _RequestPlugin = require("./RequestPlugin");
46
- const _cache = require("./cache");
47
- const _retry = require("./retry");
48
- const _validation = require("./validation");
49
- const _monitoring = require("./monitoring");
50
- const _csrfPlugin = require("./csrfPlugin");
51
- const _queue = require("./queue");
52
-
53
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../src/request/plugin/index.ts"],"sourcesContent":["/**\n * 插件模块导出\n */\n\nexport type { RequestPlugin } from './RequestPlugin';\nexport { PluginManager, PluginLifecycleStage, PluginPriority } from './RequestPlugin';\n\n// 导出企业级插件\nexport { createCachePlugin, type CachePluginConfig } from './cache';\nexport { createRetryPlugin, type RetryPluginConfig } from './retry';\nexport { createValidationPlugin, type ValidationPluginConfig } from './validation';\nexport {\n createMonitoringPlugin,\n type MonitoringPluginConfig,\n type MonitoringEvent,\n type MonitoringReporter,\n MonitoringEventType,\n} from './monitoring';\nexport { createCSRFPlugin } from './csrfPlugin';\nexport {\n createQueuePlugin,\n type QueuePluginConfig,\n type QueueTriggerCondition,\n} from './queue';"],"names":["MonitoringEventType","PluginLifecycleStage","PluginManager","PluginPriority","createCSRFPlugin","createCachePlugin","createMonitoringPlugin","createQueuePlugin","createRetryPlugin","createValidationPlugin"],"mappings":"AAAA;;CAEC;;;;;;;;;;;QAcCA;eAAAA,+BAAmB;;QAXGC;eAAAA,mCAAoB;;QAAnCC;eAAAA,4BAAa;;QAAwBC;eAAAA,6BAAc;;QAanDC;eAAAA,4BAAgB;;QAVhBC;eAAAA,wBAAiB;;QAIxBC;eAAAA,kCAAsB;;QAQtBC;eAAAA,wBAAiB;;QAXVC;eAAAA,wBAAiB;;QACjBC;eAAAA,kCAAsB;;;+BALqC;uBAGV;uBACA;4BACU;4BAO7D;4BAC0B;uBAK1B"}
@@ -1,216 +0,0 @@
1
- /**
2
- * 监控插件
3
- *
4
- * 提供请求监控能力,包括耗时、错误率、上报等
5
- */ "use strict";
6
- Object.defineProperty(exports, "__esModule", {
7
- value: true
8
- });
9
- function _export(target, all) {
10
- for(var name in all)Object.defineProperty(target, name, {
11
- enumerable: true,
12
- get: Object.getOwnPropertyDescriptor(all, name).get
13
- });
14
- }
15
- _export(exports, {
16
- get MonitoringEventType () {
17
- return MonitoringEventType;
18
- },
19
- get createMonitoringPlugin () {
20
- return createMonitoringPlugin;
21
- }
22
- });
23
- const _RequestPlugin = require("./RequestPlugin");
24
- const _logger = require("../../utils/logger");
25
- const _monitoring = require("../../utils/monitoring");
26
- const _errors = require("../../utils/errors");
27
- var MonitoringEventType = /*#__PURE__*/ function(MonitoringEventType) {
28
- /**
29
- * 请求开始
30
- */ MonitoringEventType["REQUEST_START"] = "request_start";
31
- /**
32
- * 请求成功
33
- */ MonitoringEventType["REQUEST_SUCCESS"] = "request_success";
34
- /**
35
- * 请求失败
36
- */ MonitoringEventType["REQUEST_ERROR"] = "request_error";
37
- /**
38
- * 请求完成(无论成功或失败)
39
- */ MonitoringEventType["REQUEST_COMPLETE"] = "request_complete";
40
- return MonitoringEventType;
41
- }({});
42
- function createMonitoringPlugin(config = {}) {
43
- const { enabled = true, reporter, recordStart = true, recordSuccess = true, recordError = true, recordComplete = true, slowRequestThreshold = 3000 } = config;
44
- // 如果没有提供上报函数,使用默认的 logger 输出
45
- const defaultReporter = (event)=>{
46
- _logger.logger.debug('[Request Monitoring]', event);
47
- };
48
- const report = reporter || defaultReporter;
49
- return {
50
- name: 'monitoring',
51
- priority: _RequestPlugin.PluginPriority.LOW,
52
- async onBeforeRequest (context) {
53
- if (!enabled) {
54
- return;
55
- }
56
- if (recordStart) {
57
- const event = {
58
- type: "request_start",
59
- url: context.request.url,
60
- method: context.request.method || 'GET',
61
- tags: context.request.tags,
62
- timestamp: Date.now()
63
- };
64
- try {
65
- await report(event);
66
- } catch (error) {
67
- _logger.logger.error('监控上报失败:', error);
68
- // 上报错误到监控服务
69
- const monitoring = (0, _monitoring.getMonitoring)();
70
- monitoring.captureError(error, {
71
- type: 'monitoring_report_failed',
72
- event: 'request_start'
73
- });
74
- }
75
- }
76
- },
77
- async onAfterRequest (context) {
78
- if (!enabled || !context.response) {
79
- return;
80
- }
81
- const duration = context.duration || 0;
82
- const isSlow = duration > slowRequestThreshold;
83
- if (recordSuccess) {
84
- const event = {
85
- type: "request_success",
86
- url: context.request.url,
87
- method: context.request.method || 'GET',
88
- duration,
89
- status: context.response.status,
90
- tags: context.request.tags,
91
- timestamp: Date.now()
92
- };
93
- try {
94
- await report(event);
95
- } catch (error) {
96
- _logger.logger.error('监控上报失败:', error);
97
- // 上报错误到监控服务
98
- const monitoring = (0, _monitoring.getMonitoring)();
99
- monitoring.captureError(error, {
100
- type: 'monitoring_report_failed',
101
- event: 'request_start'
102
- });
103
- }
104
- }
105
- if (recordComplete) {
106
- const event = {
107
- type: "request_complete",
108
- url: context.request.url,
109
- method: context.request.method || 'GET',
110
- duration,
111
- status: context.response.status,
112
- tags: context.request.tags,
113
- timestamp: Date.now()
114
- };
115
- try {
116
- await report(event);
117
- } catch (error) {
118
- _logger.logger.error('监控上报失败:', error);
119
- // 上报错误到监控服务
120
- const monitoring = (0, _monitoring.getMonitoring)();
121
- monitoring.captureError(error, {
122
- type: 'monitoring_report_failed',
123
- event: 'request_start'
124
- });
125
- }
126
- }
127
- // 如果是慢请求,额外记录
128
- if (isSlow) {
129
- _logger.logger.warn(`[Slow Request] ${context.request.method || 'GET'} ${context.request.url} took ${duration}ms`);
130
- // 上报慢请求到监控服务
131
- const monitoring = (0, _monitoring.getMonitoring)();
132
- monitoring.captureError(new Error(`慢请求: ${context.request.method || 'GET'} ${context.request.url} 耗时 ${duration}ms`), {
133
- type: 'slow_request',
134
- duration,
135
- method: context.request.method || 'GET',
136
- url: context.request.url
137
- });
138
- }
139
- },
140
- async onError (context) {
141
- if (!enabled || !context.error) {
142
- return;
143
- }
144
- const duration = context.duration || 0;
145
- if (recordError) {
146
- const error = context.error;
147
- const event = {
148
- type: "request_error",
149
- url: context.request.url,
150
- method: context.request.method || 'GET',
151
- duration,
152
- status: error.status,
153
- error: {
154
- type: error.type,
155
- code: error.code,
156
- message: error.message
157
- },
158
- tags: context.request.tags,
159
- timestamp: Date.now()
160
- };
161
- // 上报错误到监控服务
162
- const monitoring = (0, _monitoring.getMonitoring)();
163
- const normalizedError = _errors.errorUtils.normalizeError(error);
164
- monitoring.captureError(normalizedError, {
165
- type: 'request_error',
166
- url: context.request.url,
167
- method: context.request.method || 'GET',
168
- duration,
169
- status: error.status,
170
- errorType: error.type,
171
- errorCode: error.code
172
- });
173
- try {
174
- await report(event);
175
- } catch (reportError) {
176
- _logger.logger.error('监控上报失败:', reportError);
177
- // 上报上报失败错误到监控服务
178
- monitoring.captureError(reportError, {
179
- type: 'monitoring_report_failed',
180
- event: 'request_error'
181
- });
182
- }
183
- }
184
- if (recordComplete) {
185
- const error = context.error;
186
- const event = {
187
- type: "request_complete",
188
- url: context.request.url,
189
- method: context.request.method || 'GET',
190
- duration,
191
- status: error.status,
192
- error: {
193
- type: error.type,
194
- code: error.code,
195
- message: error.message
196
- },
197
- tags: context.request.tags,
198
- timestamp: Date.now()
199
- };
200
- try {
201
- await report(event);
202
- } catch (reportError) {
203
- _logger.logger.error('监控上报失败:', reportError);
204
- // 上报错误到监控服务
205
- const monitoring = (0, _monitoring.getMonitoring)();
206
- monitoring.captureError(reportError, {
207
- type: 'monitoring_report_failed',
208
- event: context.error ? 'request_error' : 'request_complete'
209
- });
210
- }
211
- }
212
- }
213
- };
214
- }
215
-
216
- //# sourceMappingURL=monitoring.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../src/request/plugin/monitoring.ts"],"sourcesContent":["/**\n * 监控插件\n * \n * 提供请求监控能力,包括耗时、错误率、上报等\n */\n\nimport type { RequestPlugin } from './RequestPlugin';\nimport type { RequestContext } from '../types';\nimport type { RequestError } from '../types';\nimport { PluginPriority } from './RequestPlugin';\nimport { logger } from '../../utils/logger';\nimport { getMonitoring } from '../../utils/monitoring';\nimport { errorUtils } from '../../utils/errors';\n\n/**\n * 监控事件类型\n */\nexport enum MonitoringEventType {\n /**\n * 请求开始\n */\n REQUEST_START = 'request_start',\n\n /**\n * 请求成功\n */\n REQUEST_SUCCESS = 'request_success',\n\n /**\n * 请求失败\n */\n REQUEST_ERROR = 'request_error',\n\n /**\n * 请求完成(无论成功或失败)\n */\n REQUEST_COMPLETE = 'request_complete',\n}\n\n/**\n * 监控事件数据\n */\nexport interface MonitoringEvent {\n /**\n * 事件类型\n */\n type: MonitoringEventType;\n\n /**\n * 请求 URL\n */\n url: string;\n\n /**\n * 请求方法\n */\n method: string;\n\n /**\n * 请求耗时(毫秒)\n */\n duration?: number;\n\n /**\n * HTTP 状态码\n */\n status?: number;\n\n /**\n * 错误信息(如果有)\n */\n error?: {\n type: string;\n code: string;\n message: string;\n };\n\n /**\n * 请求标签\n */\n tags?: string[];\n\n /**\n * 时间戳\n */\n timestamp: number;\n}\n\n/**\n * 监控上报函数类型\n */\nexport type MonitoringReporter = (event: MonitoringEvent) => void | Promise<void>;\n\n/**\n * 监控插件配置\n */\nexport interface MonitoringPluginConfig {\n /**\n * 是否启用监控\n */\n enabled?: boolean;\n\n /**\n * 监控上报函数\n */\n reporter?: MonitoringReporter;\n\n /**\n * 是否记录请求开始事件\n */\n recordStart?: boolean;\n\n /**\n * 是否记录请求成功事件\n */\n recordSuccess?: boolean;\n\n /**\n * 是否记录请求错误事件\n */\n recordError?: boolean;\n\n /**\n * 是否记录请求完成事件\n */\n recordComplete?: boolean;\n\n /**\n * 慢请求阈值(毫秒),超过此阈值的请求会被标记为慢请求\n */\n slowRequestThreshold?: number;\n}\n\n/**\n * 创建监控插件\n * \n * @param config - 监控插件配置\n * @returns 监控插件实例\n */\nexport function createMonitoringPlugin(config: MonitoringPluginConfig = {}): RequestPlugin {\n const {\n enabled = true,\n reporter,\n recordStart = true,\n recordSuccess = true,\n recordError = true,\n recordComplete = true,\n slowRequestThreshold = 3000,\n } = config;\n\n // 如果没有提供上报函数,使用默认的 logger 输出\n const defaultReporter: MonitoringReporter = (event) => {\n logger.debug('[Request Monitoring]', event);\n };\n\n const report: MonitoringReporter = reporter || defaultReporter;\n\n return {\n name: 'monitoring',\n priority: PluginPriority.LOW, // 低优先级,用于日志和监控\n\n async onBeforeRequest(context: RequestContext): Promise<void> {\n if (!enabled) {\n return;\n }\n\n if (recordStart) {\n const event: MonitoringEvent = {\n type: MonitoringEventType.REQUEST_START,\n url: context.request.url,\n method: context.request.method || 'GET',\n tags: context.request.tags,\n timestamp: Date.now(),\n };\n\n try {\n await report(event);\n } catch (error) {\n logger.error('监控上报失败:', error);\n // 上报错误到监控服务\n const monitoring = getMonitoring();\n monitoring.captureError(error, {\n type: 'monitoring_report_failed',\n event: 'request_start',\n });\n }\n }\n },\n\n async onAfterRequest(context: RequestContext): Promise<void> {\n if (!enabled || !context.response) {\n return;\n }\n\n const duration = context.duration || 0;\n const isSlow = duration > slowRequestThreshold;\n\n if (recordSuccess) {\n const event: MonitoringEvent = {\n type: MonitoringEventType.REQUEST_SUCCESS,\n url: context.request.url,\n method: context.request.method || 'GET',\n duration,\n status: context.response.status,\n tags: context.request.tags,\n timestamp: Date.now(),\n };\n\n try {\n await report(event);\n } catch (error) {\n logger.error('监控上报失败:', error);\n // 上报错误到监控服务\n const monitoring = getMonitoring();\n monitoring.captureError(error, {\n type: 'monitoring_report_failed',\n event: 'request_start',\n });\n }\n }\n\n if (recordComplete) {\n const event: MonitoringEvent = {\n type: MonitoringEventType.REQUEST_COMPLETE,\n url: context.request.url,\n method: context.request.method || 'GET',\n duration,\n status: context.response.status,\n tags: context.request.tags,\n timestamp: Date.now(),\n };\n\n try {\n await report(event);\n } catch (error) {\n logger.error('监控上报失败:', error);\n // 上报错误到监控服务\n const monitoring = getMonitoring();\n monitoring.captureError(error, {\n type: 'monitoring_report_failed',\n event: 'request_start',\n });\n }\n }\n\n // 如果是慢请求,额外记录\n if (isSlow) {\n logger.warn(`[Slow Request] ${context.request.method || 'GET'} ${context.request.url} took ${duration}ms`);\n // 上报慢请求到监控服务\n const monitoring = getMonitoring();\n monitoring.captureError(\n new Error(`慢请求: ${context.request.method || 'GET'} ${context.request.url} 耗时 ${duration}ms`),\n {\n type: 'slow_request',\n duration,\n method: context.request.method || 'GET',\n url: context.request.url,\n }\n );\n }\n },\n\n async onError(context: RequestContext): Promise<void> {\n if (!enabled || !context.error) {\n return;\n }\n\n const duration = context.duration || 0;\n\n if (recordError) {\n const error = context.error as RequestError;\n const event: MonitoringEvent = {\n type: MonitoringEventType.REQUEST_ERROR,\n url: context.request.url,\n method: context.request.method || 'GET',\n duration,\n status: error.status,\n error: {\n type: error.type,\n code: error.code,\n message: error.message,\n },\n tags: context.request.tags,\n timestamp: Date.now(),\n };\n\n // 上报错误到监控服务\n const monitoring = getMonitoring();\n const normalizedError = errorUtils.normalizeError(error);\n monitoring.captureError(normalizedError, {\n type: 'request_error',\n url: context.request.url,\n method: context.request.method || 'GET',\n duration,\n status: error.status,\n errorType: error.type,\n errorCode: error.code,\n });\n\n try {\n await report(event);\n } catch (reportError) {\n logger.error('监控上报失败:', reportError);\n // 上报上报失败错误到监控服务\n monitoring.captureError(reportError, {\n type: 'monitoring_report_failed',\n event: 'request_error',\n });\n }\n }\n\n if (recordComplete) {\n const error = context.error as RequestError;\n const event: MonitoringEvent = {\n type: MonitoringEventType.REQUEST_COMPLETE,\n url: context.request.url,\n method: context.request.method || 'GET',\n duration,\n status: error.status,\n error: {\n type: error.type,\n code: error.code,\n message: error.message,\n },\n tags: context.request.tags,\n timestamp: Date.now(),\n };\n\n try {\n await report(event);\n } catch (reportError) {\n logger.error('监控上报失败:', reportError);\n // 上报错误到监控服务\n const monitoring = getMonitoring();\n monitoring.captureError(reportError, {\n type: 'monitoring_report_failed',\n event: context.error ? 'request_error' : 'request_complete',\n });\n }\n }\n },\n };\n}\n"],"names":["MonitoringEventType","createMonitoringPlugin","config","enabled","reporter","recordStart","recordSuccess","recordError","recordComplete","slowRequestThreshold","defaultReporter","event","logger","debug","report","name","priority","PluginPriority","LOW","onBeforeRequest","context","type","url","request","method","tags","timestamp","Date","now","error","monitoring","getMonitoring","captureError","onAfterRequest","response","duration","isSlow","status","warn","Error","onError","code","message","normalizedError","errorUtils","normalizeError","errorType","errorCode","reportError"],"mappings":"AAAA;;;;CAIC;;;;;;;;;;;QAaWA;eAAAA;;QA0HIC;eAAAA;;;+BAlIe;wBACR;4BACO;wBACH;AAKpB,IAAA,AAAKD,6CAAAA;IACV;;GAEC;IAGD;;GAEC;IAGD;;GAEC;IAGD;;GAEC;WAlBSA;;AA0HL,SAASC,uBAAuBC,SAAiC,CAAC,CAAC;IACxE,MAAM,EACJC,UAAU,IAAI,EACdC,QAAQ,EACRC,cAAc,IAAI,EAClBC,gBAAgB,IAAI,EACpBC,cAAc,IAAI,EAClBC,iBAAiB,IAAI,EACrBC,uBAAuB,IAAI,EAC5B,GAAGP;IAEJ,6BAA6B;IAC7B,MAAMQ,kBAAsC,CAACC;QAC3CC,cAAM,CAACC,KAAK,CAAC,wBAAwBF;IACvC;IAEA,MAAMG,SAA6BV,YAAYM;IAE/C,OAAO;QACLK,MAAM;QACNC,UAAUC,6BAAc,CAACC,GAAG;QAE5B,MAAMC,iBAAgBC,OAAuB;YAC3C,IAAI,CAACjB,SAAS;gBACZ;YACF;YAEA,IAAIE,aAAa;gBACf,MAAMM,QAAyB;oBAC7BU,IAAI;oBACJC,KAAKF,QAAQG,OAAO,CAACD,GAAG;oBACxBE,QAAQJ,QAAQG,OAAO,CAACC,MAAM,IAAI;oBAClCC,MAAML,QAAQG,OAAO,CAACE,IAAI;oBAC1BC,WAAWC,KAAKC,GAAG;gBACrB;gBAEA,IAAI;oBACF,MAAMd,OAAOH;gBACf,EAAE,OAAOkB,OAAO;oBACdjB,cAAM,CAACiB,KAAK,CAAC,WAAWA;oBACxB,YAAY;oBACZ,MAAMC,aAAaC,IAAAA,yBAAa;oBAChCD,WAAWE,YAAY,CAACH,OAAO;wBAC7BR,MAAM;wBACNV,OAAO;oBACT;gBACF;YACF;QACF;QAEA,MAAMsB,gBAAeb,OAAuB;YAC1C,IAAI,CAACjB,WAAW,CAACiB,QAAQc,QAAQ,EAAE;gBACjC;YACF;YAEA,MAAMC,WAAWf,QAAQe,QAAQ,IAAI;YACrC,MAAMC,SAASD,WAAW1B;YAE1B,IAAIH,eAAe;gBACjB,MAAMK,QAAyB;oBAC7BU,IAAI;oBACJC,KAAKF,QAAQG,OAAO,CAACD,GAAG;oBACxBE,QAAQJ,QAAQG,OAAO,CAACC,MAAM,IAAI;oBAClCW;oBACAE,QAAQjB,QAAQc,QAAQ,CAACG,MAAM;oBAC/BZ,MAAML,QAAQG,OAAO,CAACE,IAAI;oBAC1BC,WAAWC,KAAKC,GAAG;gBACrB;gBAEA,IAAI;oBACF,MAAMd,OAAOH;gBACf,EAAE,OAAOkB,OAAO;oBACdjB,cAAM,CAACiB,KAAK,CAAC,WAAWA;oBACxB,YAAY;oBACZ,MAAMC,aAAaC,IAAAA,yBAAa;oBAChCD,WAAWE,YAAY,CAACH,OAAO;wBAC7BR,MAAM;wBACNV,OAAO;oBACT;gBACF;YACF;YAEA,IAAIH,gBAAgB;gBAClB,MAAMG,QAAyB;oBAC7BU,IAAI;oBACJC,KAAKF,QAAQG,OAAO,CAACD,GAAG;oBACxBE,QAAQJ,QAAQG,OAAO,CAACC,MAAM,IAAI;oBAClCW;oBACAE,QAAQjB,QAAQc,QAAQ,CAACG,MAAM;oBAC/BZ,MAAML,QAAQG,OAAO,CAACE,IAAI;oBAC1BC,WAAWC,KAAKC,GAAG;gBACrB;gBAEA,IAAI;oBACF,MAAMd,OAAOH;gBACf,EAAE,OAAOkB,OAAO;oBACdjB,cAAM,CAACiB,KAAK,CAAC,WAAWA;oBACxB,YAAY;oBACZ,MAAMC,aAAaC,IAAAA,yBAAa;oBAChCD,WAAWE,YAAY,CAACH,OAAO;wBAC7BR,MAAM;wBACNV,OAAO;oBACT;gBACF;YACF;YAEA,cAAc;YACd,IAAIyB,QAAQ;gBACVxB,cAAM,CAAC0B,IAAI,CAAC,CAAC,eAAe,EAAElB,QAAQG,OAAO,CAACC,MAAM,IAAI,MAAM,CAAC,EAAEJ,QAAQG,OAAO,CAACD,GAAG,CAAC,MAAM,EAAEa,SAAS,EAAE,CAAC;gBACzG,aAAa;gBACb,MAAML,aAAaC,IAAAA,yBAAa;gBAChCD,WAAWE,YAAY,CACrB,IAAIO,MAAM,CAAC,KAAK,EAAEnB,QAAQG,OAAO,CAACC,MAAM,IAAI,MAAM,CAAC,EAAEJ,QAAQG,OAAO,CAACD,GAAG,CAAC,IAAI,EAAEa,SAAS,EAAE,CAAC,GAC3F;oBACEd,MAAM;oBACNc;oBACAX,QAAQJ,QAAQG,OAAO,CAACC,MAAM,IAAI;oBAClCF,KAAKF,QAAQG,OAAO,CAACD,GAAG;gBAC1B;YAEJ;QACF;QAEA,MAAMkB,SAAQpB,OAAuB;YACnC,IAAI,CAACjB,WAAW,CAACiB,QAAQS,KAAK,EAAE;gBAC9B;YACF;YAEA,MAAMM,WAAWf,QAAQe,QAAQ,IAAI;YAErC,IAAI5B,aAAa;gBACf,MAAMsB,QAAQT,QAAQS,KAAK;gBAC3B,MAAMlB,QAAyB;oBAC7BU,IAAI;oBACJC,KAAKF,QAAQG,OAAO,CAACD,GAAG;oBACxBE,QAAQJ,QAAQG,OAAO,CAACC,MAAM,IAAI;oBAClCW;oBACAE,QAAQR,MAAMQ,MAAM;oBACpBR,OAAO;wBACLR,MAAMQ,MAAMR,IAAI;wBAChBoB,MAAMZ,MAAMY,IAAI;wBAChBC,SAASb,MAAMa,OAAO;oBACxB;oBACAjB,MAAML,QAAQG,OAAO,CAACE,IAAI;oBAC1BC,WAAWC,KAAKC,GAAG;gBACrB;gBAEA,YAAY;gBACZ,MAAME,aAAaC,IAAAA,yBAAa;gBAChC,MAAMY,kBAAkBC,kBAAU,CAACC,cAAc,CAAChB;gBAClDC,WAAWE,YAAY,CAACW,iBAAiB;oBACvCtB,MAAM;oBACNC,KAAKF,QAAQG,OAAO,CAACD,GAAG;oBACxBE,QAAQJ,QAAQG,OAAO,CAACC,MAAM,IAAI;oBAClCW;oBACAE,QAAQR,MAAMQ,MAAM;oBACpBS,WAAWjB,MAAMR,IAAI;oBACrB0B,WAAWlB,MAAMY,IAAI;gBACvB;gBAEA,IAAI;oBACF,MAAM3B,OAAOH;gBACf,EAAE,OAAOqC,aAAa;oBACpBpC,cAAM,CAACiB,KAAK,CAAC,WAAWmB;oBACxB,gBAAgB;oBAChBlB,WAAWE,YAAY,CAACgB,aAAa;wBACnC3B,MAAM;wBACNV,OAAO;oBACT;gBACF;YACF;YAEA,IAAIH,gBAAgB;gBAClB,MAAMqB,QAAQT,QAAQS,KAAK;gBAC3B,MAAMlB,QAAyB;oBAC7BU,IAAI;oBACJC,KAAKF,QAAQG,OAAO,CAACD,GAAG;oBACxBE,QAAQJ,QAAQG,OAAO,CAACC,MAAM,IAAI;oBAClCW;oBACAE,QAAQR,MAAMQ,MAAM;oBACpBR,OAAO;wBACLR,MAAMQ,MAAMR,IAAI;wBAChBoB,MAAMZ,MAAMY,IAAI;wBAChBC,SAASb,MAAMa,OAAO;oBACxB;oBACAjB,MAAML,QAAQG,OAAO,CAACE,IAAI;oBAC1BC,WAAWC,KAAKC,GAAG;gBACrB;gBAEA,IAAI;oBACF,MAAMd,OAAOH;gBACf,EAAE,OAAOqC,aAAa;oBACpBpC,cAAM,CAACiB,KAAK,CAAC,WAAWmB;oBACxB,YAAY;oBACZ,MAAMlB,aAAaC,IAAAA,yBAAa;oBAChCD,WAAWE,YAAY,CAACgB,aAAa;wBACnC3B,MAAM;wBACNV,OAAOS,QAAQS,KAAK,GAAG,kBAAkB;oBAC3C;gBACF;YACF;QACF;IACF;AACF"}
@@ -1,140 +0,0 @@
1
- /**
2
- * 请求队列插件
3
- *
4
- * 当检测到特定的响应 code 或 status 时,暂停后续请求并放入队列,
5
- * 执行回调方法,等待回调完成后继续执行队列中的请求
6
- */ "use strict";
7
- Object.defineProperty(exports, "__esModule", {
8
- value: true
9
- });
10
- Object.defineProperty(exports, "createQueuePlugin", {
11
- enumerable: true,
12
- get: function() {
13
- return createQueuePlugin;
14
- }
15
- });
16
- const _RequestPlugin = require("./RequestPlugin");
17
- const _RequestQueueManager = require("../utils/RequestQueueManager");
18
- /**
19
- * 检查响应是否匹配触发条件
20
- */ function matchesTrigger(response, context, trigger) {
21
- // 检查自定义检查函数
22
- if (trigger.check) {
23
- return trigger.check(response, context);
24
- }
25
- // 检查响应数据中的 code 字段
26
- if (trigger.code !== undefined) {
27
- const responseData = response.data;
28
- if (responseData && typeof responseData === 'object' && 'code' in responseData) {
29
- const code = responseData.code;
30
- if (typeof trigger.code === 'function') {
31
- if (trigger.code(code)) {
32
- return true;
33
- }
34
- } else if (code === trigger.code) {
35
- return true;
36
- }
37
- }
38
- }
39
- // 检查 HTTP 状态码
40
- if (trigger.status !== undefined) {
41
- const status = response.status;
42
- if (typeof trigger.status === 'function') {
43
- if (trigger.status(status)) {
44
- return true;
45
- }
46
- } else if (Array.isArray(trigger.status)) {
47
- if (trigger.status.includes(status)) {
48
- return true;
49
- }
50
- } else if (status === trigger.status) {
51
- return true;
52
- }
53
- }
54
- return false;
55
- }
56
- /**
57
- * 检查响应是否匹配任一触发条件
58
- */ function matchesAnyTrigger(response, context, triggers) {
59
- return triggers.some((trigger)=>matchesTrigger(response, context, trigger));
60
- }
61
- function createQueuePlugin(config = {}) {
62
- const { triggers = [], onTrigger, enabled = true, checkOnError = true, queueTimeout = 30000 } = config;
63
- if (triggers.length === 0) {
64
- // 如果没有配置触发条件,返回一个空插件
65
- return {
66
- name: 'queue',
67
- priority: _RequestPlugin.PluginPriority.HIGH,
68
- onBeforeRequest: undefined,
69
- onAfterRequest: undefined,
70
- onError: undefined
71
- };
72
- }
73
- const queueManager = (0, _RequestQueueManager.getRequestQueueManager)();
74
- return {
75
- name: 'queue',
76
- priority: _RequestPlugin.PluginPriority.HIGH,
77
- async onAfterRequest (context) {
78
- if (!enabled || !context.response) {
79
- return;
80
- }
81
- // 检查是否匹配触发条件
82
- const matched = matchesAnyTrigger(context.response, context, triggers);
83
- if (matched && onTrigger) {
84
- // 暂停队列(后续请求会被 RequestClient 自动放入队列)
85
- queueManager.pause();
86
- // 设置队列超时
87
- const timeoutId = setTimeout(()=>{
88
- queueManager.clear('队列超时');
89
- }, queueTimeout);
90
- try {
91
- // 执行回调并等待完成,然后恢复队列
92
- await queueManager.processAndResume(async ()=>{
93
- await onTrigger(context.response, context);
94
- });
95
- } catch (error) {
96
- // 回调执行失败,清空队列
97
- queueManager.clear(`回调执行失败: ${error instanceof Error ? error.message : String(error)}`);
98
- // 不抛出错误,让请求正常返回(但队列已被清空)
99
- } finally{
100
- clearTimeout(timeoutId);
101
- }
102
- }
103
- },
104
- async onError (context) {
105
- if (!enabled || !checkOnError || !context.error) {
106
- return;
107
- }
108
- // 如果有响应,检查是否匹配触发条件
109
- if (context.response) {
110
- const matched = matchesAnyTrigger(context.response, context, triggers);
111
- if (matched && onTrigger) {
112
- // 暂停队列(后续请求会被 RequestClient 自动放入队列)
113
- queueManager.pause();
114
- // 设置队列超时
115
- const timeoutId = setTimeout(()=>{
116
- queueManager.clear('队列超时');
117
- }, queueTimeout);
118
- try {
119
- // 执行回调并等待完成,然后恢复队列
120
- await queueManager.processAndResume(async ()=>{
121
- await onTrigger(context.response, context);
122
- });
123
- // 错误已被处理,返回 true 阻止错误传播
124
- return true;
125
- } catch (error) {
126
- // 回调执行失败,清空队列
127
- queueManager.clear(`回调执行失败: ${error instanceof Error ? error.message : String(error)}`);
128
- // 不处理错误,继续传播
129
- return false;
130
- } finally{
131
- clearTimeout(timeoutId);
132
- }
133
- }
134
- }
135
- return false;
136
- }
137
- };
138
- }
139
-
140
- //# sourceMappingURL=queue.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../src/request/plugin/queue.ts"],"sourcesContent":["/**\n * 请求队列插件\n * \n * 当检测到特定的响应 code 或 status 时,暂停后续请求并放入队列,\n * 执行回调方法,等待回调完成后继续执行队列中的请求\n */\n\nimport type { RequestPlugin } from './RequestPlugin';\nimport type { RequestContext, Response } from '../types';\nimport { PluginPriority } from './RequestPlugin';\nimport { getRequestQueueManager } from '../utils/RequestQueueManager';\n\n/**\n * 触发条件配置\n */\nexport interface QueueTriggerCondition {\n /**\n * 响应数据中的 code 字段值(业务状态码)\n * 如果响应数据是对象且包含 code 字段,且值匹配则触发\n */\n code?: number | string | ((code: unknown) => boolean);\n \n /**\n * HTTP 状态码\n * 如果 HTTP status 匹配则触发\n */\n status?: number | number[] | ((status: number) => boolean);\n \n /**\n * 自定义检查函数\n * 返回 true 表示应该触发队列暂停\n */\n check?: (response: Response, context: RequestContext) => boolean;\n}\n\n/**\n * 队列插件配置\n */\nexport interface QueuePluginConfig {\n /**\n * 触发条件列表\n * 当响应匹配任一条件时,会暂停队列并执行回调\n */\n triggers?: QueueTriggerCondition[];\n \n /**\n * 回调函数\n * 当检测到触发条件时执行,返回 Promise 表示异步操作\n * \n * @param response - 触发条件的响应\n * @param context - 请求上下文\n * @returns Promise 或 void\n */\n onTrigger?: (response: Response, context: RequestContext) => Promise<void> | void;\n \n /**\n * 是否启用队列功能\n * @default true\n */\n enabled?: boolean;\n \n /**\n * 是否在错误时也检查触发条件\n * @default true\n */\n checkOnError?: boolean;\n \n /**\n * 队列超时时间(毫秒)\n * 如果队列暂停超过此时间,会自动恢复并拒绝队列中的请求\n * @default 30000 (30秒)\n */\n queueTimeout?: number;\n}\n\n/**\n * 检查响应是否匹配触发条件\n */\nfunction matchesTrigger(\n response: Response,\n context: RequestContext,\n trigger: QueueTriggerCondition\n): boolean {\n // 检查自定义检查函数\n if (trigger.check) {\n return trigger.check(response, context);\n }\n \n // 检查响应数据中的 code 字段\n if (trigger.code !== undefined) {\n const responseData = response.data;\n if (responseData && typeof responseData === 'object' && 'code' in responseData) {\n const code = (responseData as { code: unknown }).code;\n \n if (typeof trigger.code === 'function') {\n if (trigger.code(code)) {\n return true;\n }\n } else if (code === trigger.code) {\n return true;\n }\n }\n }\n \n // 检查 HTTP 状态码\n if (trigger.status !== undefined) {\n const status = response.status;\n \n if (typeof trigger.status === 'function') {\n if (trigger.status(status)) {\n return true;\n }\n } else if (Array.isArray(trigger.status)) {\n if (trigger.status.includes(status)) {\n return true;\n }\n } else if (status === trigger.status) {\n return true;\n }\n }\n \n return false;\n}\n\n/**\n * 检查响应是否匹配任一触发条件\n */\nfunction matchesAnyTrigger(\n response: Response,\n context: RequestContext,\n triggers: QueueTriggerCondition[]\n): boolean {\n return triggers.some((trigger) => matchesTrigger(response, context, trigger));\n}\n\n/**\n * 创建请求队列插件\n * \n * @param config - 队列插件配置\n * @returns 队列插件实例\n * \n * @example\n * ```typescript\n * import { createRequestClient } from '@vlian/framework/request';\n * import { createQueuePlugin } from '@vlian/framework/request/plugin';\n * \n * const client = await createRequestClient({\n * plugins: [\n * createQueuePlugin({\n * triggers: [\n * { code: 401 }, // 业务 code 401 表示未授权\n * { status: 401 }, // HTTP 401 未授权\n * ],\n * onTrigger: async (response, context) => {\n * // 刷新 token 或跳转登录\n * await refreshToken();\n * },\n * }),\n * ],\n * });\n * ```\n */\nexport function createQueuePlugin(config: QueuePluginConfig = {}): RequestPlugin {\n const {\n triggers = [],\n onTrigger,\n enabled = true,\n checkOnError = true,\n queueTimeout = 30000,\n } = config;\n \n if (triggers.length === 0) {\n // 如果没有配置触发条件,返回一个空插件\n return {\n name: 'queue',\n priority: PluginPriority.HIGH,\n onBeforeRequest: undefined,\n onAfterRequest: undefined,\n onError: undefined,\n };\n }\n \n const queueManager = getRequestQueueManager();\n \n return {\n name: 'queue',\n priority: PluginPriority.HIGH, // 高优先级,确保在其他插件之前执行\n \n async onAfterRequest(context: RequestContext): Promise<Response | void> {\n if (!enabled || !context.response) {\n return;\n }\n \n // 检查是否匹配触发条件\n const matched = matchesAnyTrigger(context.response, context, triggers);\n \n if (matched && onTrigger) {\n // 暂停队列(后续请求会被 RequestClient 自动放入队列)\n queueManager.pause();\n \n // 设置队列超时\n const timeoutId = setTimeout(() => {\n queueManager.clear('队列超时');\n }, queueTimeout);\n \n try {\n // 执行回调并等待完成,然后恢复队列\n await queueManager.processAndResume(async () => {\n await onTrigger(context.response!, context);\n });\n } catch (error) {\n // 回调执行失败,清空队列\n queueManager.clear(`回调执行失败: ${error instanceof Error ? error.message : String(error)}`);\n // 不抛出错误,让请求正常返回(但队列已被清空)\n } finally {\n clearTimeout(timeoutId);\n }\n }\n },\n \n async onError(context: RequestContext): Promise<boolean | void> {\n if (!enabled || !checkOnError || !context.error) {\n return;\n }\n \n // 如果有响应,检查是否匹配触发条件\n if (context.response) {\n const matched = matchesAnyTrigger(context.response, context, triggers);\n \n if (matched && onTrigger) {\n // 暂停队列(后续请求会被 RequestClient 自动放入队列)\n queueManager.pause();\n \n // 设置队列超时\n const timeoutId = setTimeout(() => {\n queueManager.clear('队列超时');\n }, queueTimeout);\n \n try {\n // 执行回调并等待完成,然后恢复队列\n await queueManager.processAndResume(async () => {\n await onTrigger(context.response!, context);\n });\n \n // 错误已被处理,返回 true 阻止错误传播\n return true;\n } catch (error) {\n // 回调执行失败,清空队列\n queueManager.clear(`回调执行失败: ${error instanceof Error ? error.message : String(error)}`);\n // 不处理错误,继续传播\n return false;\n } finally {\n clearTimeout(timeoutId);\n }\n }\n }\n \n return false;\n },\n };\n}\n"],"names":["createQueuePlugin","matchesTrigger","response","context","trigger","check","code","undefined","responseData","data","status","Array","isArray","includes","matchesAnyTrigger","triggers","some","config","onTrigger","enabled","checkOnError","queueTimeout","length","name","priority","PluginPriority","HIGH","onBeforeRequest","onAfterRequest","onError","queueManager","getRequestQueueManager","matched","pause","timeoutId","setTimeout","clear","processAndResume","error","Error","message","String","clearTimeout"],"mappings":"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"}
@@ -1,98 +0,0 @@
1
- /**
2
- * 重试插件
3
- *
4
- * 提供请求重试能力,支持指数退避、条件重试
5
- */ "use strict";
6
- Object.defineProperty(exports, "__esModule", {
7
- value: true
8
- });
9
- Object.defineProperty(exports, "createRetryPlugin", {
10
- enumerable: true,
11
- get: function() {
12
- return createRetryPlugin;
13
- }
14
- });
15
- const _types = require("../types");
16
- const _RequestPlugin = require("./RequestPlugin");
17
- /**
18
- * 计算指数退避延迟
19
- */ function calculateExponentialBackoffDelay(attempt, baseDelay) {
20
- return baseDelay * Math.pow(2, attempt - 1);
21
- }
22
- /**
23
- * 默认重试条件
24
- */ function defaultShouldRetry(error, attempt, maxAttempts) {
25
- if (attempt >= maxAttempts) {
26
- return false;
27
- }
28
- // 如果是请求错误,检查错误类型
29
- if (error && typeof error === 'object' && 'type' in error) {
30
- const requestError = error;
31
- // 网络错误、超时错误、服务器错误(5xx)可以重试
32
- if (requestError.type === _types.RequestErrorType.NETWORK_ERROR || requestError.type === _types.RequestErrorType.TIMEOUT_ERROR || requestError.type === _types.RequestErrorType.HTTP_ERROR && requestError.status && requestError.status >= 500) {
33
- return true;
34
- }
35
- // 客户端错误(4xx)不重试,除了 408(请求超时)和 429(请求过多)
36
- if (requestError.type === _types.RequestErrorType.HTTP_ERROR && requestError.status) {
37
- return requestError.status === 408 || requestError.status === 429;
38
- }
39
- }
40
- // 其他错误不重试
41
- return false;
42
- }
43
- function createRetryPlugin(config = {}) {
44
- const { defaultMaxAttempts = 3, defaultDelay = 1000, defaultExponentialBackoff = true, enabled = true } = config;
45
- return {
46
- name: 'retry',
47
- priority: _RequestPlugin.PluginPriority.LOWEST,
48
- async onError (context) {
49
- if (!enabled || !context.error) {
50
- return;
51
- }
52
- const retryConfig = context.request.retry;
53
- if (!retryConfig) {
54
- // 如果没有配置重试,使用默认配置
55
- const maxAttempts = defaultMaxAttempts;
56
- const delay = defaultDelay;
57
- const exponentialBackoff = defaultExponentialBackoff;
58
- // 检查是否应该重试
59
- const shouldRetry = defaultShouldRetry(context.error, context.retryCount, maxAttempts);
60
- if (!shouldRetry) {
61
- return false; // 不处理错误,继续传播
62
- }
63
- // 计算延迟
64
- const retryDelay = exponentialBackoff ? calculateExponentialBackoffDelay(context.retryCount + 1, delay) : delay;
65
- // 等待后重试
66
- await new Promise((resolve)=>setTimeout(resolve, retryDelay));
67
- // 增加重试计数
68
- context.retryCount += 1;
69
- // 返回 false,让错误继续传播,触发重新请求
70
- return false;
71
- }
72
- // 使用配置的重试逻辑
73
- const maxAttempts = retryConfig.maxAttempts || defaultMaxAttempts;
74
- const shouldRetry = retryConfig.shouldRetry ? retryConfig.shouldRetry(context.error, context.retryCount) : defaultShouldRetry(context.error, context.retryCount, maxAttempts);
75
- if (!shouldRetry) {
76
- return false; // 不处理错误,继续传播
77
- }
78
- // 计算延迟
79
- let retryDelay;
80
- if (retryConfig.calculateDelay) {
81
- retryDelay = retryConfig.calculateDelay(context.retryCount + 1);
82
- } else if (retryConfig.exponentialBackoff !== false) {
83
- const baseDelay = retryConfig.delay || defaultDelay;
84
- retryDelay = calculateExponentialBackoffDelay(context.retryCount + 1, baseDelay);
85
- } else {
86
- retryDelay = retryConfig.delay || defaultDelay;
87
- }
88
- // 等待后重试
89
- await new Promise((resolve)=>setTimeout(resolve, retryDelay));
90
- // 增加重试计数
91
- context.retryCount += 1;
92
- // 返回 false,让错误继续传播,触发重新请求
93
- return false;
94
- }
95
- };
96
- }
97
-
98
- //# sourceMappingURL=retry.js.map