@withwiz/toolkit 0.1.0

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 (380) hide show
  1. package/README.md +162 -0
  2. package/dist/auth/adapters/prisma/index.d.ts +43 -0
  3. package/dist/auth/adapters/prisma/index.js +284 -0
  4. package/dist/auth/core/email/token-generator.d.ts +43 -0
  5. package/dist/auth/core/email/token-generator.js +7 -0
  6. package/dist/auth/core/jwt/client.d.ts +87 -0
  7. package/dist/auth/core/jwt/client.js +36 -0
  8. package/dist/auth/core/jwt/index.d.ts +110 -0
  9. package/dist/auth/core/jwt/index.js +10 -0
  10. package/dist/auth/core/jwt/types.d.ts +6 -0
  11. package/dist/auth/core/jwt/types.js +13 -0
  12. package/dist/auth/core/oauth/index.d.ts +51 -0
  13. package/dist/auth/core/oauth/index.js +12 -0
  14. package/dist/auth/core/password/client-helper.d.ts +44 -0
  15. package/dist/auth/core/password/client-helper.js +28 -0
  16. package/dist/auth/core/password/index.d.ts +71 -0
  17. package/dist/auth/core/password/index.js +14 -0
  18. package/dist/auth/errors/index.d.ts +49 -0
  19. package/dist/auth/errors/index.js +17 -0
  20. package/dist/auth/index.d.ts +21 -0
  21. package/dist/auth/index.js +97 -0
  22. package/dist/auth/types/index.d.ts +213 -0
  23. package/dist/auth/types/index.js +13 -0
  24. package/dist/cache/cache-config.d.ts +73 -0
  25. package/dist/cache/cache-config.js +12 -0
  26. package/dist/cache/cache-defaults.d.ts +141 -0
  27. package/dist/cache/cache-defaults.js +33 -0
  28. package/dist/cache/cache-env.d.ts +75 -0
  29. package/dist/cache/cache-env.js +25 -0
  30. package/dist/cache/cache-factory.d.ts +34 -0
  31. package/dist/cache/cache-factory.js +28 -0
  32. package/dist/cache/cache-invalidation.d.ts +90 -0
  33. package/dist/cache/cache-invalidation.js +24 -0
  34. package/dist/cache/cache-keys-legacy.d.ts +35 -0
  35. package/dist/cache/cache-keys-legacy.js +7 -0
  36. package/dist/cache/cache-redis.d.ts +74 -0
  37. package/dist/cache/cache-redis.js +24 -0
  38. package/dist/cache/cache-types.d.ts +151 -0
  39. package/dist/cache/cache-types.js +9 -0
  40. package/dist/cache/cache-wrapper.d.ts +27 -0
  41. package/dist/cache/cache-wrapper.js +22 -0
  42. package/dist/cache/cache.d.ts +14 -0
  43. package/dist/cache/cache.js +112 -0
  44. package/dist/cache/hybrid-cache-manager.d.ts +148 -0
  45. package/dist/cache/hybrid-cache-manager.js +13 -0
  46. package/dist/cache/index.d.ts +21 -0
  47. package/dist/cache/index.js +112 -0
  48. package/dist/cache/inmemory-cache-manager.d.ts +163 -0
  49. package/dist/cache/inmemory-cache-manager.js +9 -0
  50. package/dist/cache/noop-cache-manager.d.ts +36 -0
  51. package/dist/cache/noop-cache-manager.js +11 -0
  52. package/dist/cache/redis-cache-manager.d.ts +34 -0
  53. package/dist/cache/redis-cache-manager.js +11 -0
  54. package/dist/chunk-26Y7VEYG.js +93 -0
  55. package/dist/chunk-2DVWSDST.js +119 -0
  56. package/dist/chunk-2KAPUVIS.js +155 -0
  57. package/dist/chunk-2TO7WUKK.js +93 -0
  58. package/dist/chunk-34WAGUT5.js +117 -0
  59. package/dist/chunk-3DZA6AGS.js +120 -0
  60. package/dist/chunk-4DPSCTX4.js +212 -0
  61. package/dist/chunk-4KJXENRM.js +64 -0
  62. package/dist/chunk-4NWJ3WCZ.js +28 -0
  63. package/dist/chunk-4ODT3Q4A.js +86 -0
  64. package/dist/chunk-5ATB5D6S.js +40 -0
  65. package/dist/chunk-62FLBG6B.js +34 -0
  66. package/dist/chunk-62Q7DN5G.js +25 -0
  67. package/dist/chunk-65LHDFU3.js +242 -0
  68. package/dist/chunk-6C7HQIX4.js +13 -0
  69. package/dist/chunk-6D3HHYER.js +32 -0
  70. package/dist/chunk-6LTZCXNC.js +326 -0
  71. package/dist/chunk-7VJNLGAS.js +110 -0
  72. package/dist/chunk-7XFHGAJP.js +0 -0
  73. package/dist/chunk-A6EAAWMK.js +50 -0
  74. package/dist/chunk-AHDPGRXS.js +51 -0
  75. package/dist/chunk-AIH3F7JV.js +76 -0
  76. package/dist/chunk-AIHQBQ3E.js +109 -0
  77. package/dist/chunk-BKGVSC6S.js +152 -0
  78. package/dist/chunk-COK4ZXNG.js +0 -0
  79. package/dist/chunk-DEEJBDJE.js +47 -0
  80. package/dist/chunk-DH2ZHGW2.js +53 -0
  81. package/dist/chunk-EBUEBEJX.js +0 -0
  82. package/dist/chunk-EEUBKZV4.js +54 -0
  83. package/dist/chunk-EQYTE7WD.js +139 -0
  84. package/dist/chunk-EUQATJLI.js +180 -0
  85. package/dist/chunk-EZC6ETFW.js +80 -0
  86. package/dist/chunk-EZR55KV2.js +249 -0
  87. package/dist/chunk-F6LCSFSU.js +31 -0
  88. package/dist/chunk-FOKAATUQ.js +62 -0
  89. package/dist/chunk-FW3IEJ7H.js +71 -0
  90. package/dist/chunk-G26T2PRQ.js +53 -0
  91. package/dist/chunk-G4NI37NN.js +257 -0
  92. package/dist/chunk-GCZOXUDV.js +132 -0
  93. package/dist/chunk-GDWEDUHO.js +55 -0
  94. package/dist/chunk-GL2NANFH.js +434 -0
  95. package/dist/chunk-GPBOMJSZ.js +136 -0
  96. package/dist/chunk-H5I5GWAA.js +94 -0
  97. package/dist/chunk-HGC4CCKB.js +29 -0
  98. package/dist/chunk-HV3DGSSH.js +447 -0
  99. package/dist/chunk-I47QEDTX.js +193 -0
  100. package/dist/chunk-IAJNC34M.js +102 -0
  101. package/dist/chunk-IHXRF3BH.js +215 -0
  102. package/dist/chunk-IJEZ7G7S.js +26 -0
  103. package/dist/chunk-IQQKKUAV.js +151 -0
  104. package/dist/chunk-JBCDEAMW.js +35 -0
  105. package/dist/chunk-JLLMTTQ4.js +75 -0
  106. package/dist/chunk-JS5VI3OW.js +143 -0
  107. package/dist/chunk-KAWVMIRJ.js +44 -0
  108. package/dist/chunk-KMCJIL57.js +214 -0
  109. package/dist/chunk-KWTBD4CM.js +145 -0
  110. package/dist/chunk-KXAWBFJN.js +310 -0
  111. package/dist/chunk-L25BNU3E.js +56 -0
  112. package/dist/chunk-L76O3X3D.js +197 -0
  113. package/dist/chunk-LNV2E4I6.js +63 -0
  114. package/dist/chunk-MLGO3HLS.js +329 -0
  115. package/dist/chunk-MRJE6OX5.js +22 -0
  116. package/dist/chunk-MYLGYX4K.js +57 -0
  117. package/dist/chunk-N4YGR5WH.js +310 -0
  118. package/dist/chunk-OIVXOT2X.js +80 -0
  119. package/dist/chunk-ORMEWXMH.js +37 -0
  120. package/dist/chunk-POKGHK3L.js +57 -0
  121. package/dist/chunk-Q7IP4JMW.js +69 -0
  122. package/dist/chunk-RJUVBBZG.js +27 -0
  123. package/dist/chunk-S73334QY.js +89 -0
  124. package/dist/chunk-SLG26KHZ.js +101 -0
  125. package/dist/chunk-SR65BF6X.js +82 -0
  126. package/dist/chunk-SS56XFLI.js +19 -0
  127. package/dist/chunk-T3LJYAMO.js +277 -0
  128. package/dist/chunk-TDZJ6SAI.js +34 -0
  129. package/dist/chunk-TEIYA7U4.js +72 -0
  130. package/dist/chunk-TMVS4F7E.js +88 -0
  131. package/dist/chunk-TRBKJ7JT.js +137 -0
  132. package/dist/chunk-TXGNSECL.js +84 -0
  133. package/dist/chunk-TZAP5T4N.js +188 -0
  134. package/dist/chunk-UCYQNHST.js +24 -0
  135. package/dist/chunk-ULF5RDDX.js +0 -0
  136. package/dist/chunk-UXQRU3EM.js +167 -0
  137. package/dist/chunk-V5K5FYU7.js +200 -0
  138. package/dist/chunk-VDXB5DCY.js +68 -0
  139. package/dist/chunk-VSGKVZB4.js +47 -0
  140. package/dist/chunk-VWODEQ5C.js +204 -0
  141. package/dist/chunk-WDUFQFDP.js +193 -0
  142. package/dist/chunk-WHR7HPWF.js +126 -0
  143. package/dist/chunk-WSQMXMTL.js +122 -0
  144. package/dist/chunk-XHZ5L4FO.js +103 -0
  145. package/dist/chunk-XPASCCUA.js +404 -0
  146. package/dist/chunk-XRRPEBKB.js +231 -0
  147. package/dist/chunk-Y2TUZFCP.js +0 -0
  148. package/dist/chunk-Y3OTJH2S.js +473 -0
  149. package/dist/chunk-YBSHN67U.js +161 -0
  150. package/dist/chunk-YJ3TLEW3.js +100 -0
  151. package/dist/chunk-YJWLWUFK.js +105 -0
  152. package/dist/chunk-Z4D4CMDA.js +488 -0
  153. package/dist/chunk-ZHVUK5OY.js +314 -0
  154. package/dist/chunk-ZTN4X5FN.js +29 -0
  155. package/dist/chunk-ZZIKRBJU.js +96 -0
  156. package/dist/components/ui/Alert.d.ts +12 -0
  157. package/dist/components/ui/Alert.js +10 -0
  158. package/dist/components/ui/Badge.d.ts +7 -0
  159. package/dist/components/ui/Badge.js +8 -0
  160. package/dist/components/ui/Button.d.ts +7 -0
  161. package/dist/components/ui/Button.js +8 -0
  162. package/dist/components/ui/DataTable.d.ts +103 -0
  163. package/dist/components/ui/DataTable.js +606 -0
  164. package/dist/components/ui/DomainDisplay.d.ts +12 -0
  165. package/dist/components/ui/DomainDisplay.js +31 -0
  166. package/dist/components/ui/Input.d.ts +5 -0
  167. package/dist/components/ui/Input.js +8 -0
  168. package/dist/components/ui/Label.d.ts +5 -0
  169. package/dist/components/ui/Label.js +8 -0
  170. package/dist/components/ui/Pagination.d.ts +42 -0
  171. package/dist/components/ui/Pagination.js +20 -0
  172. package/dist/components/ui/Select.d.ts +15 -0
  173. package/dist/components/ui/Select.js +27 -0
  174. package/dist/components/ui/Skeleton.d.ts +6 -0
  175. package/dist/components/ui/Skeleton.js +8 -0
  176. package/dist/components/ui/TimezoneDisplay.d.ts +22 -0
  177. package/dist/components/ui/TimezoneDisplay.js +83 -0
  178. package/dist/components/ui/Tooltip.d.ts +21 -0
  179. package/dist/components/ui/Tooltip.js +94 -0
  180. package/dist/components/ui/WorldMapChart.d.ts +17 -0
  181. package/dist/components/ui/WorldMapChart.js +250 -0
  182. package/dist/components/ui/loading-bar.d.ts +20 -0
  183. package/dist/components/ui/loading-bar.js +15 -0
  184. package/dist/constants/error-codes.d.ts +389 -0
  185. package/dist/constants/error-codes.js +27 -0
  186. package/dist/constants/index.d.ts +11 -0
  187. package/dist/constants/index.js +85 -0
  188. package/dist/constants/messages.d.ts +83 -0
  189. package/dist/constants/messages.js +13 -0
  190. package/dist/constants/pagination.d.ts +43 -0
  191. package/dist/constants/pagination.js +15 -0
  192. package/dist/constants/security.d.ts +66 -0
  193. package/dist/constants/security.js +23 -0
  194. package/dist/constants/validation.d.ts +60 -0
  195. package/dist/constants/validation.js +19 -0
  196. package/dist/error/ErrorBoundary.d.ts +47 -0
  197. package/dist/error/app-error.d.ts +144 -0
  198. package/dist/error/app-error.js +10 -0
  199. package/dist/error/components/EmptyState.d.ts +50 -0
  200. package/dist/error/components/ErrorAlert.d.ts +50 -0
  201. package/dist/error/components/ErrorPage.d.ts +39 -0
  202. package/dist/error/components/LoadingState.d.ts +37 -0
  203. package/dist/error/components/index.d.ts +13 -0
  204. package/dist/error/components/index.js +18 -0
  205. package/dist/error/core/locale-detector.d.ts +44 -0
  206. package/dist/error/core/locale-detector.js +9 -0
  207. package/dist/error/error-display.d.ts +55 -0
  208. package/dist/error/error-display.js +24 -0
  209. package/dist/error/error-handler.d.ts +118 -0
  210. package/dist/error/error-handler.js +18 -0
  211. package/dist/error/friendly-messages-v2.d.ts +46 -0
  212. package/dist/error/friendly-messages-v2.js +15 -0
  213. package/dist/error/friendly-messages.d.ts +22 -0
  214. package/dist/error/friendly-messages.js +12 -0
  215. package/dist/error/hooks/index.d.ts +7 -0
  216. package/dist/error/hooks/index.js +14 -0
  217. package/dist/error/hooks/useErrorHandler.d.ts +67 -0
  218. package/dist/error/hooks/useErrorHandler.js +14 -0
  219. package/dist/error/index.d.ts +26 -0
  220. package/dist/error/index.js +289 -0
  221. package/dist/error/logging/error-logger.d.ts +77 -0
  222. package/dist/error/logging/error-logger.js +10 -0
  223. package/dist/error/logging/index.d.ts +9 -0
  224. package/dist/error/logging/index.js +35 -0
  225. package/dist/error/logging/transports/base.d.ts +30 -0
  226. package/dist/error/logging/transports/base.js +7 -0
  227. package/dist/error/logging/transports/console.d.ts +40 -0
  228. package/dist/error/logging/transports/console.js +9 -0
  229. package/dist/error/logging/transports/file.d.ts +49 -0
  230. package/dist/error/logging/transports/file.js +8 -0
  231. package/dist/error/logging/transports/index.d.ts +12 -0
  232. package/dist/error/logging/transports/index.js +25 -0
  233. package/dist/error/logging/transports/sentry.d.ts +44 -0
  234. package/dist/error/logging/transports/sentry.js +9 -0
  235. package/dist/error/logging/transports/slack.d.ts +51 -0
  236. package/dist/error/logging/transports/slack.js +9 -0
  237. package/dist/error/logging/types.d.ts +83 -0
  238. package/dist/error/logging/types.js +7 -0
  239. package/dist/error/messages/en.d.ts +5 -0
  240. package/dist/error/messages/en.js +7 -0
  241. package/dist/error/messages/index.d.ts +40 -0
  242. package/dist/error/messages/index.js +17 -0
  243. package/dist/error/messages/ko.d.ts +5 -0
  244. package/dist/error/messages/ko.js +7 -0
  245. package/dist/error/messages/types.d.ts +30 -0
  246. package/dist/error/messages/types.js +0 -0
  247. package/dist/error/recovery/circuit-breaker.d.ts +85 -0
  248. package/dist/error/recovery/circuit-breaker.js +9 -0
  249. package/dist/error/recovery/degradation.d.ts +56 -0
  250. package/dist/error/recovery/degradation.js +7 -0
  251. package/dist/error/recovery/fallback.d.ts +55 -0
  252. package/dist/error/recovery/fallback.js +11 -0
  253. package/dist/error/recovery/index.d.ts +12 -0
  254. package/dist/error/recovery/index.js +26 -0
  255. package/dist/error/recovery/retry.d.ts +44 -0
  256. package/dist/error/recovery/retry.js +7 -0
  257. package/dist/geolocation/batch-processor.d.ts +33 -0
  258. package/dist/geolocation/batch-processor.js +10 -0
  259. package/dist/geolocation/index.d.ts +14 -0
  260. package/dist/geolocation/index.js +36 -0
  261. package/dist/geolocation/providers/base-provider.d.ts +33 -0
  262. package/dist/geolocation/providers/base-provider.js +9 -0
  263. package/dist/geolocation/providers/index.d.ts +54 -0
  264. package/dist/geolocation/providers/index.js +29 -0
  265. package/dist/geolocation/providers/ip-api-provider.d.ts +17 -0
  266. package/dist/geolocation/providers/ip-api-provider.js +8 -0
  267. package/dist/geolocation/providers/ipapi-co-provider.d.ts +17 -0
  268. package/dist/geolocation/providers/ipapi-co-provider.js +8 -0
  269. package/dist/geolocation/providers/ipgeolocation-provider.d.ts +18 -0
  270. package/dist/geolocation/providers/ipgeolocation-provider.js +8 -0
  271. package/dist/geolocation/providers/maxmind-provider.d.ts +18 -0
  272. package/dist/geolocation/providers/maxmind-provider.js +8 -0
  273. package/dist/hooks/useDataTable.d.ts +51 -0
  274. package/dist/hooks/useDataTable.js +149 -0
  275. package/dist/hooks/useDebounce.d.ts +7 -0
  276. package/dist/hooks/useDebounce.js +7 -0
  277. package/dist/hooks/useExitIntent.d.ts +35 -0
  278. package/dist/hooks/useExitIntent.js +72 -0
  279. package/dist/hooks/useTimezone.d.ts +19 -0
  280. package/dist/hooks/useTimezone.js +11 -0
  281. package/dist/logger/logger.d.ts +11 -0
  282. package/dist/logger/logger.js +17 -0
  283. package/dist/middleware/auth.d.ts +87 -0
  284. package/dist/middleware/auth.js +20 -0
  285. package/dist/middleware/cors.d.ts +30 -0
  286. package/dist/middleware/cors.js +10 -0
  287. package/dist/middleware/error-handler.d.ts +23 -0
  288. package/dist/middleware/error-handler.js +13 -0
  289. package/dist/middleware/index.d.ts +16 -0
  290. package/dist/middleware/index.js +72 -0
  291. package/dist/middleware/init-request.d.ts +18 -0
  292. package/dist/middleware/init-request.js +8 -0
  293. package/dist/middleware/middleware-chain.d.ts +53 -0
  294. package/dist/middleware/middleware-chain.js +8 -0
  295. package/dist/middleware/rate-limit.d.ts +82 -0
  296. package/dist/middleware/rate-limit.js +14 -0
  297. package/dist/middleware/response-logger.d.ts +22 -0
  298. package/dist/middleware/response-logger.js +8 -0
  299. package/dist/middleware/security.d.ts +31 -0
  300. package/dist/middleware/security.js +9 -0
  301. package/dist/middleware/types.d.ts +45 -0
  302. package/dist/middleware/types.js +0 -0
  303. package/dist/middleware/wrappers.d.ts +91 -0
  304. package/dist/middleware/wrappers.js +32 -0
  305. package/dist/storage/r2-storage.d.ts +38 -0
  306. package/dist/storage/r2-storage.js +105 -0
  307. package/dist/system/cpu.d.ts +2 -0
  308. package/dist/system/cpu.js +9 -0
  309. package/dist/system/disk.d.ts +2 -0
  310. package/dist/system/disk.js +9 -0
  311. package/dist/system/environment.d.ts +8 -0
  312. package/dist/system/environment.js +9 -0
  313. package/dist/system/health-check.d.ts +26 -0
  314. package/dist/system/health-check.js +10 -0
  315. package/dist/system/index.d.ts +51 -0
  316. package/dist/system/index.js +194 -0
  317. package/dist/system/memory.d.ts +2 -0
  318. package/dist/system/memory.js +9 -0
  319. package/dist/system/network.d.ts +2 -0
  320. package/dist/system/network.js +9 -0
  321. package/dist/system/types.d.ts +93 -0
  322. package/dist/system/types.js +0 -0
  323. package/dist/system/utils.d.ts +12 -0
  324. package/dist/system/utils.js +26 -0
  325. package/dist/types/api.d.ts +80 -0
  326. package/dist/types/api.js +0 -0
  327. package/dist/types/database.d.ts +38 -0
  328. package/dist/types/database.js +0 -0
  329. package/dist/types/env.d.ts +105 -0
  330. package/dist/types/env.js +0 -0
  331. package/dist/types/geoip.d.ts +152 -0
  332. package/dist/types/geoip.js +0 -0
  333. package/dist/types/i18n.d.ts +11 -0
  334. package/dist/types/i18n.js +0 -0
  335. package/dist/types/qr-code.d.ts +139 -0
  336. package/dist/types/qr-code.js +75 -0
  337. package/dist/types/user.d.ts +54 -0
  338. package/dist/types/user.js +0 -0
  339. package/dist/utils/api-helpers.d.ts +147 -0
  340. package/dist/utils/api-helpers.js +30 -0
  341. package/dist/utils/client/client-utils.d.ts +3 -0
  342. package/dist/utils/client/client-utils.js +9 -0
  343. package/dist/utils/client/qr-code.d.ts +16 -0
  344. package/dist/utils/client/qr-code.js +215 -0
  345. package/dist/utils/cors.d.ts +40 -0
  346. package/dist/utils/cors.js +21 -0
  347. package/dist/utils/csv-export.d.ts +97 -0
  348. package/dist/utils/csv-export.js +20 -0
  349. package/dist/utils/error-message-formatter.d.ts +17 -0
  350. package/dist/utils/error-message-formatter.js +11 -0
  351. package/dist/utils/error-processor.d.ts +70 -0
  352. package/dist/utils/error-processor.js +34 -0
  353. package/dist/utils/format-number.d.ts +17 -0
  354. package/dist/utils/format-number.js +9 -0
  355. package/dist/utils/index.d.ts +13 -0
  356. package/dist/utils/index.js +160 -0
  357. package/dist/utils/input-validation.d.ts +88 -0
  358. package/dist/utils/input-validation.js +223 -0
  359. package/dist/utils/ip-utils.d.ts +15 -0
  360. package/dist/utils/ip-utils.js +91 -0
  361. package/dist/utils/optimistic-lock.d.ts +27 -0
  362. package/dist/utils/optimistic-lock.js +16 -0
  363. package/dist/utils/sanitizer.d.ts +72 -0
  364. package/dist/utils/sanitizer.js +19 -0
  365. package/dist/utils/shared-utils.d.ts +25 -0
  366. package/dist/utils/shared-utils.js +43 -0
  367. package/dist/utils/short-code-generator.d.ts +24 -0
  368. package/dist/utils/short-code-generator.js +9 -0
  369. package/dist/utils/timezone.d.ts +56 -0
  370. package/dist/utils/timezone.js +29 -0
  371. package/dist/utils/type-guards.d.ts +164 -0
  372. package/dist/utils/type-guards.js +59 -0
  373. package/dist/utils/url-normalizer.d.ts +53 -0
  374. package/dist/utils/url-normalizer.js +21 -0
  375. package/dist/validators/index.d.ts +7 -0
  376. package/dist/validators/index.js +13 -0
  377. package/dist/validators/password-validator.d.ts +86 -0
  378. package/dist/validators/password-validator.js +13 -0
  379. package/dist/world_countries-C2WUL2CQ.js +279 -0
  380. package/package.json +129 -0
@@ -0,0 +1,100 @@
1
+ import {
2
+ BaseTransport
3
+ } from "./chunk-HGC4CCKB.js";
4
+
5
+ // src/error/logging/transports/file.ts
6
+ var FileTransport = class extends BaseTransport {
7
+ constructor(options = {}) {
8
+ const isServer = typeof window === "undefined";
9
+ super("file", isServer && options.enabled !== false);
10
+ this.fs = null;
11
+ this.path = null;
12
+ this.filePath = options.filePath || "./logs/error.log";
13
+ this.maxSize = options.maxSize || 10 * 1024 * 1024;
14
+ this.maxFiles = options.maxFiles || 5;
15
+ if (isServer) {
16
+ this.loadModules();
17
+ }
18
+ }
19
+ /**
20
+ * 모듈 로드 (동적 import)
21
+ */
22
+ async loadModules() {
23
+ try {
24
+ this.fs = await import("fs");
25
+ this.path = await import("path");
26
+ } catch (error) {
27
+ console.error("[FileTransport] Failed to load fs/path modules:", error);
28
+ this.disable();
29
+ }
30
+ }
31
+ async log(entry) {
32
+ if (!this.fs || !this.path) {
33
+ return;
34
+ }
35
+ try {
36
+ const dir = this.path.dirname(this.filePath);
37
+ if (!this.fs.existsSync(dir)) {
38
+ this.fs.mkdirSync(dir, { recursive: true });
39
+ }
40
+ const logLine = this.format(entry);
41
+ await this.rotateIfNeeded();
42
+ this.fs.appendFileSync(this.filePath, logLine + "\n", "utf8");
43
+ } catch (error) {
44
+ console.error("[FileTransport] Failed to write log:", error);
45
+ }
46
+ }
47
+ /**
48
+ * 로그 포맷팅 (JSON Lines)
49
+ */
50
+ format(entry) {
51
+ const logObject = {
52
+ timestamp: entry.timestamp.toISOString(),
53
+ level: entry.level,
54
+ message: entry.message,
55
+ context: entry.context,
56
+ error: entry.error ? {
57
+ message: entry.error.message,
58
+ stack: entry.error.stack
59
+ } : void 0
60
+ };
61
+ return JSON.stringify(logObject);
62
+ }
63
+ /**
64
+ * 파일 rotation
65
+ */
66
+ async rotateIfNeeded() {
67
+ if (!this.fs || !this.path) {
68
+ return;
69
+ }
70
+ try {
71
+ if (!this.fs.existsSync(this.filePath)) {
72
+ return;
73
+ }
74
+ const stats = this.fs.statSync(this.filePath);
75
+ if (stats.size < this.maxSize) {
76
+ return;
77
+ }
78
+ const ext = this.path.extname(this.filePath);
79
+ const base = this.filePath.slice(0, -ext.length);
80
+ for (let i = this.maxFiles - 1; i >= 1; i--) {
81
+ const oldPath = `${base}.${i}${ext}`;
82
+ const newPath = `${base}.${i + 1}${ext}`;
83
+ if (this.fs.existsSync(oldPath)) {
84
+ if (i === this.maxFiles - 1) {
85
+ this.fs.unlinkSync(oldPath);
86
+ } else {
87
+ this.fs.renameSync(oldPath, newPath);
88
+ }
89
+ }
90
+ }
91
+ this.fs.renameSync(this.filePath, `${base}.1${ext}`);
92
+ } catch (error) {
93
+ console.error("[FileTransport] Failed to rotate log file:", error);
94
+ }
95
+ }
96
+ };
97
+
98
+ export {
99
+ FileTransport
100
+ };
@@ -0,0 +1,105 @@
1
+ import {
2
+ cn
3
+ } from "./chunk-62FLBG6B.js";
4
+
5
+ // src/components/ui/Pagination.tsx
6
+ import { ChevronLeft, ChevronRight, MoreHorizontal } from "lucide-react";
7
+ import { jsx, jsxs } from "react/jsx-runtime";
8
+ function Pagination({ children, className }) {
9
+ return /* @__PURE__ */ jsx(
10
+ "nav",
11
+ {
12
+ className: cn("mx-auto flex w-full justify-center", className),
13
+ role: "navigation",
14
+ "aria-label": "pagination",
15
+ children
16
+ }
17
+ );
18
+ }
19
+ function PaginationContent({ children, className }) {
20
+ return /* @__PURE__ */ jsx("ul", { className: cn("flex flex-row items-center gap-1", className), children });
21
+ }
22
+ function PaginationItem({ children, className }) {
23
+ return /* @__PURE__ */ jsx("li", { className: cn("", className), children });
24
+ }
25
+ function PaginationLink({
26
+ children,
27
+ href,
28
+ onClick,
29
+ isActive = false,
30
+ className
31
+ }) {
32
+ return /* @__PURE__ */ jsx(
33
+ "a",
34
+ {
35
+ href,
36
+ onClick,
37
+ className: cn(
38
+ "inline-flex items-center justify-center whitespace-nowrap rounded-md text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50",
39
+ isActive ? "h-10 px-4 bg-primary text-primary-foreground" : "h-10 px-4 hover:bg-accent hover:text-accent-foreground",
40
+ className
41
+ ),
42
+ children
43
+ }
44
+ );
45
+ }
46
+ function PaginationPrevious({
47
+ href,
48
+ onClick,
49
+ className,
50
+ children
51
+ }) {
52
+ return /* @__PURE__ */ jsxs(
53
+ "a",
54
+ {
55
+ href,
56
+ onClick,
57
+ className: cn(
58
+ "inline-flex items-center justify-center whitespace-nowrap rounded-md text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 h-10 px-4 hover:bg-accent hover:text-accent-foreground",
59
+ className
60
+ ),
61
+ children: [
62
+ /* @__PURE__ */ jsx(ChevronLeft, { className: "h-4 w-4" }),
63
+ /* @__PURE__ */ jsx("span", { className: "ml-2", children: children || "Previous" })
64
+ ]
65
+ }
66
+ );
67
+ }
68
+ function PaginationNext({
69
+ href,
70
+ onClick,
71
+ className,
72
+ children
73
+ }) {
74
+ return /* @__PURE__ */ jsxs(
75
+ "a",
76
+ {
77
+ href,
78
+ onClick,
79
+ className: cn(
80
+ "inline-flex items-center justify-center whitespace-nowrap rounded-md text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 h-10 px-4 hover:bg-accent hover:text-accent-foreground",
81
+ className
82
+ ),
83
+ children: [
84
+ /* @__PURE__ */ jsx("span", { className: "mr-2", children: children || "Next" }),
85
+ /* @__PURE__ */ jsx(ChevronRight, { className: "h-4 w-4" })
86
+ ]
87
+ }
88
+ );
89
+ }
90
+ function PaginationEllipsis({ className }) {
91
+ return /* @__PURE__ */ jsxs("span", { className: cn("flex h-10 w-10 items-center justify-center", className), children: [
92
+ /* @__PURE__ */ jsx(MoreHorizontal, { className: "h-4 w-4" }),
93
+ /* @__PURE__ */ jsx("span", { className: "sr-only", children: "More pages" })
94
+ ] });
95
+ }
96
+
97
+ export {
98
+ Pagination,
99
+ PaginationContent,
100
+ PaginationItem,
101
+ PaginationLink,
102
+ PaginationPrevious,
103
+ PaginationNext,
104
+ PaginationEllipsis
105
+ };
@@ -0,0 +1,488 @@
1
+ import {
2
+ DEFAULT_INMEMORY_CONFIG
3
+ } from "./chunk-SS56XFLI.js";
4
+ import {
5
+ logger
6
+ } from "./chunk-EZR55KV2.js";
7
+ import {
8
+ __spreadProps,
9
+ __spreadValues
10
+ } from "./chunk-ORMEWXMH.js";
11
+
12
+ // src/cache/inmemory-cache-manager.ts
13
+ var InMemoryCacheManager = class _InMemoryCacheManager {
14
+ constructor(prefix, config) {
15
+ this.accessOrder = [];
16
+ this.currentMemoryBytes = 0;
17
+ this.cleanupTimer = null;
18
+ this.prefix = prefix;
19
+ this.cache = /* @__PURE__ */ new Map();
20
+ this.config = __spreadValues(__spreadValues({}, DEFAULT_INMEMORY_CONFIG), config);
21
+ this.metrics = {
22
+ hits: 0,
23
+ misses: 0,
24
+ evictions: 0,
25
+ expirations: 0,
26
+ totalRequests: 0,
27
+ hitRate: 0
28
+ };
29
+ this.startCleanupTimer();
30
+ logger.debug("[InMemoryCache] Initialized", {
31
+ prefix,
32
+ maxSize: this.config.maxSize,
33
+ maxMemoryMB: this.config.maxMemoryMB,
34
+ evictionPolicy: this.config.evictionPolicy
35
+ });
36
+ }
37
+ // ============================================================================
38
+ // Public Methods (CacheManager 인터페이스와 동일)
39
+ // ============================================================================
40
+ /**
41
+ * 캐시에서 값 조회
42
+ */
43
+ async get(key) {
44
+ const fullKey = this.getFullKey(key);
45
+ this.metrics.totalRequests++;
46
+ const entry = this.cache.get(fullKey);
47
+ if (!entry) {
48
+ this.metrics.misses++;
49
+ this.updateHitRate();
50
+ logger.debug(`[Cache:M] miss: ${fullKey}`);
51
+ return null;
52
+ }
53
+ if (this.isExpired(entry)) {
54
+ this.deleteEntry(fullKey);
55
+ this.metrics.misses++;
56
+ this.metrics.expirations++;
57
+ this.updateHitRate();
58
+ logger.debug(`[Cache:M] miss (expired): ${fullKey}`);
59
+ return null;
60
+ }
61
+ entry.accessedAt = Date.now();
62
+ this.updateAccessOrder(fullKey);
63
+ this.metrics.hits++;
64
+ this.updateHitRate();
65
+ logger.debug(`[Cache:M] hit: ${fullKey}`, {
66
+ key: fullKey,
67
+ prefix: this.prefix
68
+ });
69
+ return entry.value;
70
+ }
71
+ /**
72
+ * 캐시에 값 저장
73
+ */
74
+ async set(key, value, ttl) {
75
+ const fullKey = this.getFullKey(key);
76
+ const actualTTL = ttl != null ? ttl : this.config.defaultTTL;
77
+ const size = this.estimateSize(value);
78
+ while (this.needsEviction(size)) {
79
+ this.evict();
80
+ }
81
+ const existingEntry = this.cache.get(fullKey);
82
+ if (existingEntry) {
83
+ this.currentMemoryBytes -= existingEntry.size;
84
+ this.removeFromAccessOrder(fullKey);
85
+ }
86
+ const now = Date.now();
87
+ const entry = {
88
+ value,
89
+ expiresAt: now + actualTTL * 1e3,
90
+ size,
91
+ accessedAt: now,
92
+ createdAt: now
93
+ };
94
+ this.cache.set(fullKey, entry);
95
+ this.accessOrder.push(fullKey);
96
+ this.currentMemoryBytes += size;
97
+ }
98
+ /**
99
+ * 캐시에서 항목 삭제
100
+ */
101
+ async delete(key) {
102
+ const fullKey = this.getFullKey(key);
103
+ this.deleteEntry(fullKey);
104
+ logger.debug("[InMemoryCache] Cache deleted", {
105
+ key: fullKey,
106
+ prefix: this.prefix
107
+ });
108
+ }
109
+ /**
110
+ * 패턴 매칭으로 캐시 삭제
111
+ * 간단한 glob 패턴 지원 (* 와일드카드)
112
+ */
113
+ async deletePattern(pattern) {
114
+ const fullPattern = this.getFullKey(pattern);
115
+ const regex = this.patternToRegex(fullPattern);
116
+ const keysToDelete = [];
117
+ for (const key of this.cache.keys()) {
118
+ if (regex.test(key)) {
119
+ keysToDelete.push(key);
120
+ }
121
+ }
122
+ for (const key of keysToDelete) {
123
+ this.deleteEntry(key);
124
+ }
125
+ logger.debug("[InMemoryCache] Pattern deleted", {
126
+ pattern: fullPattern,
127
+ deletedCount: keysToDelete.length,
128
+ prefix: this.prefix
129
+ });
130
+ }
131
+ /**
132
+ * 키 존재 여부 확인
133
+ */
134
+ async exists(key) {
135
+ const fullKey = this.getFullKey(key);
136
+ const entry = this.cache.get(fullKey);
137
+ if (!entry) {
138
+ return false;
139
+ }
140
+ if (this.isExpired(entry)) {
141
+ this.deleteEntry(fullKey);
142
+ return false;
143
+ }
144
+ return true;
145
+ }
146
+ /**
147
+ * 값 증가 (카운터용)
148
+ */
149
+ async increment(key, value = 1) {
150
+ const fullKey = this.getFullKey(key);
151
+ const entry = this.cache.get(fullKey);
152
+ let currentValue = 0;
153
+ if (entry && !this.isExpired(entry)) {
154
+ currentValue = typeof entry.value === "number" ? entry.value : 0;
155
+ }
156
+ const newValue = currentValue + value;
157
+ await this.set(key, newValue);
158
+ return newValue;
159
+ }
160
+ /**
161
+ * TTL 설정/갱신
162
+ */
163
+ async expire(key, ttl) {
164
+ const fullKey = this.getFullKey(key);
165
+ const entry = this.cache.get(fullKey);
166
+ if (entry) {
167
+ entry.expiresAt = Date.now() + ttl * 1e3;
168
+ }
169
+ }
170
+ /**
171
+ * 전체 캐시 초기화
172
+ */
173
+ clear() {
174
+ this.cache.clear();
175
+ this.accessOrder = [];
176
+ this.currentMemoryBytes = 0;
177
+ logger.info("[InMemoryCache] Cache cleared", { prefix: this.prefix });
178
+ }
179
+ /**
180
+ * 리소스 정리 (서버 종료 시 호출)
181
+ */
182
+ destroy() {
183
+ if (this.cleanupTimer) {
184
+ clearInterval(this.cleanupTimer);
185
+ this.cleanupTimer = null;
186
+ }
187
+ this.clear();
188
+ logger.info("[InMemoryCache] Instance destroyed", { prefix: this.prefix });
189
+ }
190
+ // ============================================================================
191
+ // Metrics & Stats
192
+ // ============================================================================
193
+ /**
194
+ * 캐시 메트릭 조회
195
+ */
196
+ getMetrics() {
197
+ return __spreadValues({}, this.metrics);
198
+ }
199
+ /**
200
+ * 캐시 통계 조회
201
+ */
202
+ getStats() {
203
+ const memoryUsageMB = this.currentMemoryBytes / (1024 * 1024);
204
+ const maxMemoryBytes = this.config.maxMemoryMB * 1024 * 1024;
205
+ return {
206
+ itemCount: this.cache.size,
207
+ memoryUsageMB: Math.round(memoryUsageMB * 100) / 100,
208
+ maxSize: this.config.maxSize,
209
+ maxMemoryMB: this.config.maxMemoryMB,
210
+ utilizationPercent: Math.round(this.cache.size / this.config.maxSize * 100),
211
+ memoryUtilizationPercent: Math.round(this.currentMemoryBytes / maxMemoryBytes * 100)
212
+ };
213
+ }
214
+ /**
215
+ * 연결 상태 조회 (인메모리는 항상 연결됨)
216
+ */
217
+ getConnectionStatus() {
218
+ return {
219
+ isConnected: true,
220
+ type: "memory",
221
+ prefix: this.prefix
222
+ };
223
+ }
224
+ /**
225
+ * 연결 체크 (인메모리는 항상 true)
226
+ */
227
+ async checkConnection() {
228
+ return true;
229
+ }
230
+ /**
231
+ * 설정 조회
232
+ */
233
+ getConfig() {
234
+ return __spreadProps(__spreadValues({}, this.config), {
235
+ prefix: this.prefix
236
+ });
237
+ }
238
+ // ============================================================================
239
+ // Private Methods
240
+ // ============================================================================
241
+ /**
242
+ * 전체 키 생성 (prefix 포함)
243
+ */
244
+ getFullKey(key) {
245
+ return `${this.prefix}:${key}`;
246
+ }
247
+ /**
248
+ * 항목 만료 여부 확인
249
+ */
250
+ isExpired(entry) {
251
+ return Date.now() > entry.expiresAt;
252
+ }
253
+ /**
254
+ * 항목 삭제 (내부용)
255
+ */
256
+ deleteEntry(fullKey) {
257
+ const entry = this.cache.get(fullKey);
258
+ if (entry) {
259
+ this.currentMemoryBytes -= entry.size;
260
+ this.cache.delete(fullKey);
261
+ this.removeFromAccessOrder(fullKey);
262
+ }
263
+ }
264
+ /**
265
+ * 메모리 크기 추정
266
+ * JSON 직렬화 크기 * 2 (UTF-16) + 객체 오버헤드
267
+ */
268
+ estimateSize(value) {
269
+ try {
270
+ const jsonSize = JSON.stringify(value).length;
271
+ return jsonSize * 2 + 100;
272
+ } catch (e) {
273
+ return 200;
274
+ }
275
+ }
276
+ /**
277
+ * eviction 필요 여부 확인
278
+ */
279
+ needsEviction(newItemSize) {
280
+ const maxMemoryBytes = this.config.maxMemoryMB * 1024 * 1024;
281
+ return this.cache.size >= this.config.maxSize || this.currentMemoryBytes + newItemSize > maxMemoryBytes;
282
+ }
283
+ /**
284
+ * 교체 정책에 따른 항목 제거
285
+ */
286
+ evict() {
287
+ if (this.cache.size === 0) {
288
+ return;
289
+ }
290
+ for (const [key, entry] of this.cache) {
291
+ if (this.isExpired(entry)) {
292
+ this.deleteEntry(key);
293
+ this.metrics.evictions++;
294
+ this.metrics.expirations++;
295
+ return;
296
+ }
297
+ }
298
+ switch (this.config.evictionPolicy) {
299
+ case "lru":
300
+ this.evictLRU();
301
+ break;
302
+ case "fifo":
303
+ this.evictFIFO();
304
+ break;
305
+ case "ttl":
306
+ this.evictTTL();
307
+ break;
308
+ default:
309
+ this.evictLRU();
310
+ }
311
+ this.metrics.evictions++;
312
+ }
313
+ /**
314
+ * LRU 교체: 가장 오래 접근되지 않은 항목 제거
315
+ */
316
+ evictLRU() {
317
+ const lruKey = this.accessOrder.shift();
318
+ if (lruKey) {
319
+ this.deleteEntry(lruKey);
320
+ logger.debug("[InMemoryCache] LRU eviction", {
321
+ evictedKey: lruKey,
322
+ prefix: this.prefix
323
+ });
324
+ }
325
+ }
326
+ /**
327
+ * FIFO 교체: 가장 먼저 들어온 항목 제거
328
+ */
329
+ evictFIFO() {
330
+ let oldestKey = null;
331
+ let oldestTime = Infinity;
332
+ for (const [key, entry] of this.cache) {
333
+ if (entry.createdAt < oldestTime) {
334
+ oldestTime = entry.createdAt;
335
+ oldestKey = key;
336
+ }
337
+ }
338
+ if (oldestKey) {
339
+ this.deleteEntry(oldestKey);
340
+ logger.debug("[InMemoryCache] FIFO eviction", {
341
+ evictedKey: oldestKey,
342
+ prefix: this.prefix
343
+ });
344
+ }
345
+ }
346
+ /**
347
+ * TTL 교체: 가장 빨리 만료될 항목 제거
348
+ */
349
+ evictTTL() {
350
+ let nearestExpiryKey = null;
351
+ let nearestExpiryTime = Infinity;
352
+ for (const [key, entry] of this.cache) {
353
+ if (entry.expiresAt < nearestExpiryTime) {
354
+ nearestExpiryTime = entry.expiresAt;
355
+ nearestExpiryKey = key;
356
+ }
357
+ }
358
+ if (nearestExpiryKey) {
359
+ this.deleteEntry(nearestExpiryKey);
360
+ logger.debug("[InMemoryCache] TTL eviction", {
361
+ evictedKey: nearestExpiryKey,
362
+ prefix: this.prefix
363
+ });
364
+ }
365
+ }
366
+ /**
367
+ * 접근 순서 업데이트 (LRU용)
368
+ */
369
+ updateAccessOrder(key) {
370
+ const index = this.accessOrder.indexOf(key);
371
+ if (index !== -1) {
372
+ this.accessOrder.splice(index, 1);
373
+ }
374
+ this.accessOrder.push(key);
375
+ }
376
+ /**
377
+ * 접근 순서에서 제거
378
+ */
379
+ removeFromAccessOrder(key) {
380
+ const index = this.accessOrder.indexOf(key);
381
+ if (index !== -1) {
382
+ this.accessOrder.splice(index, 1);
383
+ }
384
+ }
385
+ /**
386
+ * 히트율 업데이트
387
+ */
388
+ updateHitRate() {
389
+ if (this.metrics.totalRequests > 0) {
390
+ this.metrics.hitRate = Math.round(this.metrics.hits / this.metrics.totalRequests * 1e4) / 100;
391
+ }
392
+ }
393
+ /**
394
+ * glob 패턴을 정규식으로 변환
395
+ */
396
+ patternToRegex(pattern) {
397
+ const escaped = pattern.replace(/[.+^${}()|[\]\\]/g, "\\$&").replace(/\*/g, ".*").replace(/\?/g, ".");
398
+ return new RegExp(`^${escaped}$`);
399
+ }
400
+ /**
401
+ * 만료 항목 정리 타이머 시작
402
+ */
403
+ startCleanupTimer() {
404
+ if (this.cleanupTimer) {
405
+ return;
406
+ }
407
+ this.cleanupTimer = setInterval(() => {
408
+ this.cleanupExpired();
409
+ }, this.config.cleanupInterval);
410
+ if (this.cleanupTimer.unref) {
411
+ this.cleanupTimer.unref();
412
+ }
413
+ }
414
+ /**
415
+ * 만료된 항목 일괄 정리
416
+ */
417
+ cleanupExpired() {
418
+ const now = Date.now();
419
+ let cleanedCount = 0;
420
+ for (const [key, entry] of this.cache) {
421
+ if (now > entry.expiresAt) {
422
+ this.deleteEntry(key);
423
+ this.metrics.expirations++;
424
+ cleanedCount++;
425
+ }
426
+ }
427
+ if (cleanedCount > 0) {
428
+ logger.debug("[InMemoryCache] Expired items cleaned", {
429
+ cleanedCount,
430
+ remainingCount: this.cache.size,
431
+ prefix: this.prefix
432
+ });
433
+ }
434
+ }
435
+ // ============================================================================
436
+ // Static Factory (globalThis 사용으로 프로세스 레벨 싱글톤 보장)
437
+ // ============================================================================
438
+ /**
439
+ * 전역 인스턴스 맵 가져오기 (HMR 안전)
440
+ */
441
+ static getGlobalInstances() {
442
+ if (!globalThis.__inMemoryCacheManagerInstances) {
443
+ globalThis.__inMemoryCacheManagerInstances = /* @__PURE__ */ new Map();
444
+ }
445
+ return globalThis.__inMemoryCacheManagerInstances;
446
+ }
447
+ /**
448
+ * 싱글톤 인스턴스 가져오기
449
+ */
450
+ static getInstance(prefix, config) {
451
+ const instances = _InMemoryCacheManager.getGlobalInstances();
452
+ if (!instances.has(prefix)) {
453
+ instances.set(prefix, new _InMemoryCacheManager(prefix, config));
454
+ }
455
+ return instances.get(prefix);
456
+ }
457
+ /**
458
+ * 모든 인스턴스 종료
459
+ */
460
+ static destroyAll() {
461
+ const instances = _InMemoryCacheManager.getGlobalInstances();
462
+ for (const instance of instances.values()) {
463
+ instance.destroy();
464
+ }
465
+ instances.clear();
466
+ }
467
+ /**
468
+ * 인스턴스 초기화 (테스트용)
469
+ */
470
+ static clearInstances() {
471
+ _InMemoryCacheManager.getGlobalInstances().clear();
472
+ }
473
+ /**
474
+ * 모든 인스턴스의 통계 조회
475
+ */
476
+ static getAllStats() {
477
+ const stats = {};
478
+ const instances = _InMemoryCacheManager.getGlobalInstances();
479
+ for (const [prefix, instance] of instances) {
480
+ stats[prefix] = instance.getStats();
481
+ }
482
+ return stats;
483
+ }
484
+ };
485
+
486
+ export {
487
+ InMemoryCacheManager
488
+ };