@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,119 @@
1
+ import {
2
+ getErrorCategory
3
+ } from "./chunk-Y3OTJH2S.js";
4
+
5
+ // src/error/friendly-messages.ts
6
+ var koMessages = {
7
+ // 검증 (400xx)
8
+ 40001: { title: "\uC785\uB825 \uC815\uBCF4\uB97C \uD655\uC778\uD574 \uC8FC\uC138\uC694", description: "\uC785\uB825\uD558\uC2E0 \uC815\uBCF4 \uC911 \uC77C\uBD80\uAC00 \uC62C\uBC14\uB974\uC9C0 \uC54A\uC2B5\uB2C8\uB2E4.", action: "\uC785\uB825 \uB0B4\uC6A9\uC744 \uB2E4\uC2DC \uD655\uC778\uD574 \uC8FC\uC138\uC694." },
9
+ 40002: { title: "\uC694\uCCAD\uC744 \uCC98\uB9AC\uD560 \uC218 \uC5C6\uC5B4\uC694", description: "\uC694\uCCAD \uD615\uC2DD\uC774 \uC62C\uBC14\uB974\uC9C0 \uC54A\uC2B5\uB2C8\uB2E4.", action: "\uD398\uC774\uC9C0\uB97C \uC0C8\uB85C\uACE0\uCE68\uD574 \uC8FC\uC138\uC694." },
10
+ 40003: { title: "\uC785\uB825\uAC12\uC774 \uC62C\uBC14\uB974\uC9C0 \uC54A\uC544\uC694", description: "\uD5C8\uC6A9\uB418\uC9C0 \uC54A\uB294 \uD615\uC2DD\uC785\uB2C8\uB2E4.", action: "\uC62C\uBC14\uB978 \uD615\uC2DD\uC73C\uB85C \uC785\uB825\uD574 \uC8FC\uC138\uC694." },
11
+ 40004: { title: "\uD544\uC218 \uC815\uBCF4\uAC00 \uBE60\uC84C\uC5B4\uC694", description: "\uD544\uC218 \uD56D\uBAA9\uC774 \uBE44\uC5B4 \uC788\uC2B5\uB2C8\uB2E4.", action: "\uBAA8\uB4E0 \uD544\uC218 \uD56D\uBAA9\uC744 \uC785\uB825\uD574 \uC8FC\uC138\uC694." },
12
+ 40005: { title: "URL \uD615\uC2DD\uC744 \uD655\uC778\uD574 \uC8FC\uC138\uC694", description: "https://\uB85C \uC2DC\uC791\uD558\uB294 URL\uC744 \uC785\uB825\uD574 \uC8FC\uC138\uC694.", action: "\uC608: https://example.com" },
13
+ 40006: { title: "\uC774\uBA54\uC77C \uD615\uC2DD\uC744 \uD655\uC778\uD574 \uC8FC\uC138\uC694", description: "\uC62C\uBC14\uB978 \uC774\uBA54\uC77C \uC8FC\uC18C\uAC00 \uC544\uB2D9\uB2C8\uB2E4.", action: "\uC608: user@example.com" },
14
+ 40007: { title: "\uB354 \uC548\uC804\uD55C \uBE44\uBC00\uBC88\uD638\uAC00 \uD544\uC694\uD574\uC694", description: "8\uC790 \uC774\uC0C1, \uC601\uBB38/\uC22B\uC790/\uD2B9\uC218\uBB38\uC790 \uD3EC\uD568", action: "\uB354 \uBCF5\uC7A1\uD55C \uBE44\uBC00\uBC88\uD638\uB97C \uC124\uC815\uD574 \uC8FC\uC138\uC694." },
15
+ 40008: { title: "\uBCC4\uCE6D \uD615\uC2DD\uC744 \uD655\uC778\uD574 \uC8FC\uC138\uC694", description: "\uC601\uBB38, \uC22B\uC790, \uD558\uC774\uD508(-)\uB9CC \uC0AC\uC6A9 \uAC00\uB2A5", action: "\uC608: my-link-123" },
16
+ // 인증 (401xx)
17
+ 40101: { title: "\uB85C\uADF8\uC778\uC774 \uD544\uC694\uD574\uC694", description: "\uC774 \uAE30\uB2A5\uC740 \uB85C\uADF8\uC778\uC774 \uD544\uC694\uD569\uB2C8\uB2E4.", action: "\uB85C\uADF8\uC778 \uD6C4 \uB2E4\uC2DC \uC2DC\uB3C4\uD574 \uC8FC\uC138\uC694." },
18
+ 40102: { title: "\uC778\uC99D \uC815\uBCF4\uAC00 \uC62C\uBC14\uB974\uC9C0 \uC54A\uC544\uC694", description: "\uB85C\uADF8\uC778 \uC0C1\uD0DC\uAC00 \uC720\uD6A8\uD558\uC9C0 \uC54A\uC2B5\uB2C8\uB2E4.", action: "\uB2E4\uC2DC \uB85C\uADF8\uC778\uD574 \uC8FC\uC138\uC694." },
19
+ 40103: { title: "\uB85C\uADF8\uC778\uC774 \uB9CC\uB8CC\uB418\uC5C8\uC5B4\uC694", description: "\uBCF4\uC548\uC744 \uC704\uD574 \uC138\uC158\uC774 \uB9CC\uB8CC\uB418\uC5C8\uC2B5\uB2C8\uB2E4.", action: "\uB2E4\uC2DC \uB85C\uADF8\uC778\uD574 \uC8FC\uC138\uC694." },
20
+ 40106: { title: "\uB85C\uADF8\uC778\uC5D0 \uC2E4\uD328\uD588\uC5B4\uC694", description: "\uC774\uBA54\uC77C \uB610\uB294 \uBE44\uBC00\uBC88\uD638\uAC00 \uC77C\uCE58\uD558\uC9C0 \uC54A\uC2B5\uB2C8\uB2E4.", action: "\uB2E4\uC2DC \uC2DC\uB3C4\uD574 \uC8FC\uC138\uC694." },
21
+ 40107: { title: "\uC138\uC158\uC774 \uC885\uB8CC\uB418\uC5C8\uC5B4\uC694", description: "\uC790\uB3D9 \uB85C\uADF8\uC544\uC6C3\uB418\uC5C8\uC2B5\uB2C8\uB2E4.", action: "\uB2E4\uC2DC \uB85C\uADF8\uC778\uD574 \uC8FC\uC138\uC694." },
22
+ // 권한 (403xx)
23
+ 40304: { title: "\uC811\uADFC \uAD8C\uD55C\uC774 \uC5C6\uC5B4\uC694", description: "\uC774 \uAE30\uB2A5\uC5D0 \uB300\uD55C \uAD8C\uD55C\uC774 \uC5C6\uC2B5\uB2C8\uB2E4.", action: "\uAD00\uB9AC\uC790\uC5D0\uAC8C \uBB38\uC758\uD574 \uC8FC\uC138\uC694." },
24
+ 40305: { title: "\uC774\uBA54\uC77C \uC778\uC99D\uC774 \uD544\uC694\uD574\uC694", description: "\uC774\uBA54\uC77C \uC778\uC99D\uC744 \uBA3C\uC800 \uC644\uB8CC\uD574 \uC8FC\uC138\uC694.", action: "\uBA54\uC77C\uD568\uC744 \uD655\uC778\uD574 \uC8FC\uC138\uC694." },
25
+ 40308: { title: "\uACC4\uC815\uC774 \uBE44\uD65C\uC131\uD654\uB418\uC5C8\uC5B4\uC694", description: "\uC11C\uBE44\uC2A4\uB97C \uC774\uC6A9\uD560 \uC218 \uC5C6\uC2B5\uB2C8\uB2E4.", action: "\uACE0\uAC1D\uC13C\uD130\uB85C \uBB38\uC758\uD574 \uC8FC\uC138\uC694." },
26
+ 40309: { title: "\uACC4\uC815\uC774 \uC7A0\uAE08\uB418\uC5C8\uC5B4\uC694", description: "\uB85C\uADF8\uC778 \uC2E4\uD328\uB85C \uACC4\uC815\uC774 \uC7A0\uACBC\uC2B5\uB2C8\uB2E4.", action: "\uC7A0\uC2DC \uD6C4 \uB2E4\uC2DC \uC2DC\uB3C4\uD574 \uC8FC\uC138\uC694." },
27
+ // 리소스 (404xx)
28
+ 40401: { title: "\uCC3E\uC744 \uC218 \uC5C6\uC5B4\uC694", description: "\uC694\uCCAD\uD558\uC2E0 \uD56D\uBAA9\uC774 \uC874\uC7AC\uD558\uC9C0 \uC54A\uC2B5\uB2C8\uB2E4.", action: "\uC8FC\uC18C\uB97C \uD655\uC778\uD574 \uC8FC\uC138\uC694." },
29
+ 40402: { title: "\uC0AC\uC6A9\uC790\uB97C \uCC3E\uC744 \uC218 \uC5C6\uC5B4\uC694", description: "\uD574\uB2F9 \uC0AC\uC6A9\uC790\uAC00 \uC874\uC7AC\uD558\uC9C0 \uC54A\uC2B5\uB2C8\uB2E4." },
30
+ 40403: { title: "\uB9C1\uD06C\uB97C \uCC3E\uC744 \uC218 \uC5C6\uC5B4\uC694", description: "\uB2E8\uCD95 \uB9C1\uD06C\uAC00 \uC874\uC7AC\uD558\uC9C0 \uC54A\uC2B5\uB2C8\uB2E4.", action: "\uB9C1\uD06C \uC8FC\uC18C\uB97C \uD655\uC778\uD574 \uC8FC\uC138\uC694." },
31
+ 40408: { title: "\uD0DC\uADF8\uB97C \uCC3E\uC744 \uC218 \uC5C6\uC5B4\uC694", description: "\uD0DC\uADF8\uAC00 \uC874\uC7AC\uD558\uC9C0 \uC54A\uC2B5\uB2C8\uB2E4." },
32
+ 40409: { title: "\uC990\uACA8\uCC3E\uAE30\uB97C \uCC3E\uC744 \uC218 \uC5C6\uC5B4\uC694", description: "\uD56D\uBAA9\uC774 \uC874\uC7AC\uD558\uC9C0 \uC54A\uC2B5\uB2C8\uB2E4." },
33
+ 40410: { title: "\uADF8\uB8F9\uC744 \uCC3E\uC744 \uC218 \uC5C6\uC5B4\uC694", description: "\uADF8\uB8F9\uC774 \uC874\uC7AC\uD558\uC9C0 \uC54A\uC2B5\uB2C8\uB2E4." },
34
+ // 충돌 (409xx)
35
+ 40904: { title: "\uCDA9\uB3CC\uC774 \uBC1C\uC0DD\uD588\uC5B4\uC694", description: "\uAE30\uC874 \uB370\uC774\uD130\uC640 \uCDA9\uB3CC\uD569\uB2C8\uB2E4.", action: "\uC7A0\uC2DC \uD6C4 \uB2E4\uC2DC \uC2DC\uB3C4\uD574 \uC8FC\uC138\uC694." },
36
+ 40905: { title: "\uC774\uBBF8 \uC874\uC7AC\uD574\uC694", description: "\uB3D9\uC77C\uD55C \uD56D\uBAA9\uC774 \uC788\uC2B5\uB2C8\uB2E4.", action: "\uB2E4\uB978 \uAC12\uC744 \uC0AC\uC6A9\uD574 \uC8FC\uC138\uC694." },
37
+ 40906: { title: "\uC774\uBBF8 \uB4F1\uB85D\uB41C \uC774\uBA54\uC77C\uC774\uC5D0\uC694", description: "\uB2E4\uB978 \uACC4\uC815\uC5D0\uC11C \uC0AC\uC6A9 \uC911\uC785\uB2C8\uB2E4.", action: "\uB2E4\uB978 \uC774\uBA54\uC77C\uC744 \uC0AC\uC6A9\uD574 \uC8FC\uC138\uC694." },
38
+ 40907: { title: "\uC774\uBBF8 \uC0AC\uC6A9 \uC911\uC778 \uBCC4\uCE6D\uC774\uC5D0\uC694", description: "\uB2E4\uB978 \uB9C1\uD06C\uC5D0\uC11C \uC0AC\uC6A9 \uC911\uC785\uB2C8\uB2E4.", action: "\uB2E4\uB978 \uBCC4\uCE6D\uC744 \uC785\uB825\uD574 \uC8FC\uC138\uC694." },
39
+ // 비즈니스 (422xx)
40
+ 42201: { title: "\uCC98\uB9AC\uD560 \uC218 \uC5C6\uC5B4\uC694", description: "\uD604\uC7AC \uC0C1\uD0DC\uC5D0\uC11C \uCC98\uB9AC\uD560 \uC218 \uC5C6\uC2B5\uB2C8\uB2E4.", action: "\uC870\uAC74\uC744 \uD655\uC778\uD574 \uC8FC\uC138\uC694." },
41
+ 42202: { title: "\uC9C0\uAE08\uC740 \uD560 \uC218 \uC5C6\uB294 \uC791\uC5C5\uC774\uC5D0\uC694", description: "\uD604\uC7AC \uC0C1\uD0DC\uC5D0\uC11C \uBD88\uAC00\uB2A5\uD569\uB2C8\uB2E4." },
42
+ 42203: { title: "\uC0AC\uC6A9\uB7C9\uC744 \uCD08\uACFC\uD588\uC5B4\uC694", description: "\uD55C\uB3C4\uB97C \uCD08\uACFC\uD588\uC2B5\uB2C8\uB2E4.", action: "\uD50C\uB79C \uC5C5\uADF8\uB808\uC774\uB4DC\uB97C \uACE0\uB824\uD574 \uC8FC\uC138\uC694." },
43
+ 42204: { title: "\uB9CC\uB8CC\uB41C \uB9C1\uD06C\uC608\uC694", description: "\uC720\uD6A8 \uAE30\uAC04\uC774 \uC9C0\uB0AC\uC2B5\uB2C8\uB2E4.", action: "\uC0C8 \uB9C1\uD06C\uB97C \uC0DD\uC131\uD574 \uC8FC\uC138\uC694." },
44
+ 42205: { title: "\uBE44\uD65C\uC131\uD654\uB41C \uB9C1\uD06C\uC608\uC694", description: "\uC0AC\uC6A9\uC774 \uC911\uC9C0\uB418\uC5C8\uC2B5\uB2C8\uB2E4.", action: "\uC18C\uC720\uC790\uC5D0\uAC8C \uBB38\uC758\uD574 \uC8FC\uC138\uC694." },
45
+ 42206: { title: "\uBE44\uBC00\uBC88\uD638\uAC00 \uD544\uC694\uD574\uC694", description: "\uBE44\uBC00\uBC88\uD638\uB97C \uC785\uB825\uD574\uC57C \uD569\uB2C8\uB2E4.", action: "\uBE44\uBC00\uBC88\uD638\uB97C \uC785\uB825\uD574 \uC8FC\uC138\uC694." },
46
+ 42207: { title: "\uBE44\uBC00\uBC88\uD638\uAC00 \uD2C0\uB838\uC5B4\uC694", description: "\uBE44\uBC00\uBC88\uD638\uAC00 \uC62C\uBC14\uB974\uC9C0 \uC54A\uC2B5\uB2C8\uB2E4.", action: "\uB2E4\uC2DC \uD655\uC778\uD574 \uC8FC\uC138\uC694." },
47
+ 42208: { title: "\uC0AC\uC6A9\uD560 \uC218 \uC5C6\uB294 \uBCC4\uCE6D\uC774\uC5D0\uC694", description: "\uC2DC\uC2A4\uD15C \uC608\uC57D\uC5B4\uC785\uB2C8\uB2E4.", action: "\uB2E4\uB978 \uBCC4\uCE6D\uC744 \uC120\uD0DD\uD574 \uC8FC\uC138\uC694." },
48
+ 42209: { title: "\uC774\uBBF8 \uC990\uACA8\uCC3E\uAE30\uC5D0 \uC788\uC5B4\uC694", description: "\uC774\uBBF8 \uCD94\uAC00\uB418\uC5B4 \uC788\uC2B5\uB2C8\uB2E4." },
49
+ 42210: { title: "\uC0AD\uC81C\uD560 \uC218 \uC5C6\uC5B4\uC694", description: "\uBCF8\uC778 \uAD00\uB9AC\uC790 \uACC4\uC815\uC740 \uC0AD\uC81C \uBD88\uAC00\uD569\uB2C8\uB2E4." },
50
+ 42211: { title: "\uD30C\uC77C\uC774 \uB108\uBB34 \uCEE4\uC694", description: "\uCD5C\uB300 \uD06C\uAE30\uB97C \uCD08\uACFC\uD588\uC2B5\uB2C8\uB2E4.", action: "\uC791\uC740 \uD30C\uC77C\uC744 \uC120\uD0DD\uD574 \uC8FC\uC138\uC694." },
51
+ 42212: { title: "\uC9C0\uC6D0\uD558\uC9C0 \uC54A\uB294 \uD30C\uC77C \uD615\uC2DD\uC774\uC5D0\uC694", description: "\uC5C5\uB85C\uB4DC\uD560 \uC218 \uC5C6\uC2B5\uB2C8\uB2E4.", action: "\uC9C0\uC6D0 \uD615\uC2DD\uC744 \uD655\uC778\uD574 \uC8FC\uC138\uC694." },
52
+ // Rate Limit (429xx)
53
+ 42901: { title: "\uC7A0\uC2DC \uC26C\uC5B4\uAC00\uC138\uC694", description: "\uC694\uCCAD\uC774 \uB108\uBB34 \uB9CE\uC2B5\uB2C8\uB2E4.", action: "\uC7A0\uC2DC \uD6C4 \uB2E4\uC2DC \uC2DC\uB3C4\uD574 \uC8FC\uC138\uC694." },
54
+ 42902: { title: "\uC624\uB298 \uC0AC\uC6A9\uB7C9\uC744 \uBAA8\uB450 \uC0AC\uC6A9\uD588\uC5B4\uC694", description: "\uC77C\uC77C \uD55C\uB3C4\uC5D0 \uB3C4\uB2EC\uD588\uC2B5\uB2C8\uB2E4.", action: "\uB0B4\uC77C \uB2E4\uC2DC \uC774\uC6A9\uD574 \uC8FC\uC138\uC694." },
55
+ 42903: { title: "API \uD560\uB2F9\uB7C9\uC744 \uCD08\uACFC\uD588\uC5B4\uC694", description: "API \uD55C\uB3C4\uB97C \uCD08\uACFC\uD588\uC2B5\uB2C8\uB2E4.", action: "\uD50C\uB79C \uC5C5\uADF8\uB808\uC774\uB4DC\uB97C \uACE0\uB824\uD574 \uC8FC\uC138\uC694." },
56
+ // 서버 (500xx)
57
+ 50001: { title: "\uBB38\uC81C\uAC00 \uBC1C\uC0DD\uD588\uC5B4\uC694", description: "\uC11C\uBC84 \uC624\uB958\uAC00 \uBC1C\uC0DD\uD588\uC2B5\uB2C8\uB2E4.", action: "\uC7A0\uC2DC \uD6C4 \uB2E4\uC2DC \uC2DC\uB3C4\uD574 \uC8FC\uC138\uC694." },
58
+ 50002: { title: "\uC77C\uC2DC\uC801\uC778 \uC624\uB958\uC608\uC694", description: "\uACE7 \uBCF5\uAD6C\uB429\uB2C8\uB2E4.", action: "\uC7A0\uC2DC \uD6C4 \uB2E4\uC2DC \uC2DC\uB3C4\uD574 \uC8FC\uC138\uC694." },
59
+ 50003: { title: "\uB370\uC774\uD130 \uCC98\uB9AC \uC624\uB958\uC608\uC694", description: "\uB370\uC774\uD130 \uCC98\uB9AC \uC911 \uBB38\uC81C\uAC00 \uBC1C\uC0DD\uD588\uC2B5\uB2C8\uB2E4.", action: "\uC7A0\uC2DC \uD6C4 \uB2E4\uC2DC \uC2DC\uB3C4\uD574 \uC8FC\uC138\uC694." },
60
+ 50006: { title: "\uC774\uBA54\uC77C\uC744 \uBCF4\uB0B4\uC9C0 \uBABB\uD588\uC5B4\uC694", description: "\uC774\uBA54\uC77C \uC804\uC1A1\uC5D0 \uC2E4\uD328\uD588\uC2B5\uB2C8\uB2E4.", action: "\uC7A0\uC2DC \uD6C4 \uB2E4\uC2DC \uC2DC\uB3C4\uD574 \uC8FC\uC138\uC694." },
61
+ 50007: { title: "\uC77C\uC2DC\uC801\uC778 \uC624\uB958\uC608\uC694", description: "\uCE90\uC2DC \uCC98\uB9AC \uC911 \uBB38\uC81C\uAC00 \uC788\uC2B5\uB2C8\uB2E4.", action: "\uD398\uC774\uC9C0\uB97C \uC0C8\uB85C\uACE0\uCE68\uD574 \uC8FC\uC138\uC694." },
62
+ 50008: { title: "\uD30C\uC77C \uC5C5\uB85C\uB4DC\uC5D0 \uC2E4\uD328\uD588\uC5B4\uC694", description: "\uD30C\uC77C \uC800\uC7A5 \uC911 \uBB38\uC81C\uAC00 \uC788\uC2B5\uB2C8\uB2E4.", action: "\uB2E4\uC2DC \uC2DC\uB3C4\uD574 \uC8FC\uC138\uC694." },
63
+ // 서비스 불가 (503xx)
64
+ 50304: { title: "\uC678\uBD80 \uC11C\uBE44\uC2A4 \uC5F0\uACB0 \uC2E4\uD328", description: "\uC678\uBD80 \uC11C\uBE44\uC2A4\uAC00 \uC751\uB2F5\uD558\uC9C0 \uC54A\uC2B5\uB2C8\uB2E4.", action: "\uC7A0\uC2DC \uD6C4 \uB2E4\uC2DC \uC2DC\uB3C4\uD574 \uC8FC\uC138\uC694." },
65
+ 50305: { title: "\uC11C\uBE44\uC2A4 \uC810\uAC80 \uC911\uC774\uC5D0\uC694", description: "\uC810\uAC80 \uC911\uC785\uB2C8\uB2E4.", action: "\uC7A0\uC2DC \uD6C4 \uB2E4\uC2DC \uBC29\uBB38\uD574 \uC8FC\uC138\uC694." },
66
+ // 보안 (403xx - 71~79)
67
+ 40371: { title: "\uC811\uADFC\uC774 \uCC28\uB2E8\uB418\uC5C8\uC5B4\uC694", description: "\uBCF4\uC548 \uC815\uCC45\uC73C\uB85C \uCC28\uB2E8\uB418\uC5C8\uC2B5\uB2C8\uB2E4.", action: "\uC815\uC0C1\uC801\uC778 \uBC29\uBC95\uC73C\uB85C \uB2E4\uC2DC \uC2DC\uB3C4\uD574 \uC8FC\uC138\uC694." },
68
+ 40372: { title: "\uBCF4\uC548 \uAC80\uC99D \uC2E4\uD328", description: "\uBCF4\uC548 \uD1A0\uD070\uC774 \uB9CC\uB8CC\uB418\uC5C8\uC2B5\uB2C8\uB2E4.", action: "\uD398\uC774\uC9C0\uB97C \uC0C8\uB85C\uACE0\uCE68\uD574 \uC8FC\uC138\uC694." },
69
+ 40373: { title: "\uC0AC\uC6A9\uD560 \uC218 \uC5C6\uB294 URL\uC774\uC5D0\uC694", description: "\uBCF4\uC548\uC0C1 \uCC28\uB2E8\uB41C URL\uC785\uB2C8\uB2E4.", action: "\uB2E4\uB978 URL\uC744 \uC0AC\uC6A9\uD574 \uC8FC\uC138\uC694." },
70
+ 40374: { title: "\uBE44\uC815\uC0C1 \uD65C\uB3D9 \uAC10\uC9C0", description: "\uC77C\uC2DC\uC801\uC73C\uB85C \uC81C\uD55C\uB418\uC5C8\uC2B5\uB2C8\uB2E4.", action: "\uACE0\uAC1D\uC13C\uD130\uB85C \uBB38\uC758\uD574 \uC8FC\uC138\uC694." },
71
+ 40375: { title: "IP\uAC00 \uCC28\uB2E8\uB418\uC5C8\uC5B4\uC694", description: "\uBCF4\uC548 \uC815\uCC45\uC5D0 \uC758\uD574 \uCC28\uB2E8\uB418\uC5C8\uC2B5\uB2C8\uB2E4.", action: "\uACE0\uAC1D\uC13C\uD130\uB85C \uBB38\uC758\uD574 \uC8FC\uC138\uC694." },
72
+ 40376: { title: "CORS \uC815\uCC45 \uC704\uBC18\uC774\uC5D0\uC694", description: "\uD5C8\uC6A9\uB418\uC9C0 \uC54A\uC740 \uCD9C\uCC98\uC5D0\uC11C\uC758 \uC694\uCCAD\uC785\uB2C8\uB2E4.", action: "\uC62C\uBC14\uB978 \uC8FC\uC18C\uB85C \uC811\uC18D\uD574 \uC8FC\uC138\uC694." }
73
+ };
74
+ var defaultMessages = {
75
+ ko: { title: "\uBB38\uC81C\uAC00 \uBC1C\uC0DD\uD588\uC5B4\uC694", description: "\uC608\uC0C1\uCE58 \uBABB\uD55C \uC624\uB958\uAC00 \uBC1C\uC0DD\uD588\uC2B5\uB2C8\uB2E4.", action: "\uC7A0\uC2DC \uD6C4 \uB2E4\uC2DC \uC2DC\uB3C4\uD574 \uC8FC\uC138\uC694." },
76
+ en: { title: "Something went wrong", description: "An unexpected error occurred.", action: "Please try again later." }
77
+ };
78
+ var categoryIcons = {
79
+ validation: "\u26A0\uFE0F",
80
+ auth: "\u{1F510}",
81
+ permission: "\u{1F6AB}",
82
+ resource: "\u{1F50D}",
83
+ conflict: "\u26A1",
84
+ business: "\u{1F4CB}",
85
+ rateLimit: "\u23F1\uFE0F",
86
+ server: "\u{1F527}",
87
+ security: "\u{1F6E1}\uFE0F",
88
+ unknown: "\u274C"
89
+ };
90
+ var categorySeverity = {
91
+ validation: "warning",
92
+ auth: "warning",
93
+ permission: "warning",
94
+ resource: "info",
95
+ conflict: "warning",
96
+ business: "warning",
97
+ rateLimit: "warning",
98
+ server: "error",
99
+ security: "critical",
100
+ unknown: "error"
101
+ };
102
+ function getFriendlyMessage(code, locale = "ko") {
103
+ return koMessages[code] || defaultMessages[locale];
104
+ }
105
+ function getErrorDisplayInfo(code, locale = "ko") {
106
+ const message = getFriendlyMessage(code, locale);
107
+ const category = getErrorCategory(code);
108
+ return { code, title: message.title, description: message.description, action: message.action, icon: categoryIcons[category], severity: categorySeverity[category] };
109
+ }
110
+ function formatFriendlyError(code, locale = "ko") {
111
+ const { title, description } = getFriendlyMessage(code, locale);
112
+ return `${title} - ${description} [${code}]`;
113
+ }
114
+
115
+ export {
116
+ getFriendlyMessage,
117
+ getErrorDisplayInfo,
118
+ formatFriendlyError
119
+ };
@@ -0,0 +1,155 @@
1
+ import {
2
+ ERROR_CODES,
3
+ formatErrorMessage
4
+ } from "./chunk-Y3OTJH2S.js";
5
+
6
+ // src/utils/api-helpers.ts
7
+ import { NextResponse } from "next/server";
8
+ function validateAndParse(schema, data) {
9
+ var _a;
10
+ const result = schema.safeParse(data);
11
+ if (!result.success) {
12
+ const firstIssue = ((_a = result.error.issues[0]) == null ? void 0 : _a.message) || ERROR_CODES.VALIDATION_ERROR.message;
13
+ return {
14
+ success: false,
15
+ response: NextResponse.json(
16
+ {
17
+ success: false,
18
+ error: {
19
+ code: ERROR_CODES.VALIDATION_ERROR.code,
20
+ message: formatErrorMessage(ERROR_CODES.VALIDATION_ERROR.code, firstIssue),
21
+ details: { issues: result.error.issues }
22
+ }
23
+ },
24
+ { status: ERROR_CODES.VALIDATION_ERROR.status }
25
+ )
26
+ };
27
+ }
28
+ return {
29
+ success: true,
30
+ data: result.data
31
+ };
32
+ }
33
+ function parsePagination(req, defaultLimit = 20, maxLimit = 100) {
34
+ const { searchParams } = new URL(req.url);
35
+ const page = Math.max(1, parseInt(searchParams.get("page") || "1", 10));
36
+ const limit = Math.min(
37
+ maxLimit,
38
+ Math.max(1, parseInt(searchParams.get("limit") || String(defaultLimit), 10))
39
+ );
40
+ const skip = (page - 1) * limit;
41
+ return { page, limit, skip };
42
+ }
43
+ function parseSort(req, defaultSortBy = "createdAt", defaultOrder = "desc") {
44
+ const { searchParams } = new URL(req.url);
45
+ const sortBy = searchParams.get("sortBy") || searchParams.get("sort") || defaultSortBy;
46
+ const order = searchParams.get("order") || defaultOrder;
47
+ const sortOrder = order === "asc" ? "asc" : "desc";
48
+ return { sortBy, sortOrder };
49
+ }
50
+ function parseFilters(req, allowedKeys) {
51
+ const { searchParams } = new URL(req.url);
52
+ const filters = {};
53
+ allowedKeys.forEach((key) => {
54
+ const value = searchParams.get(key);
55
+ if (value !== null) {
56
+ filters[key] = value;
57
+ }
58
+ });
59
+ return filters;
60
+ }
61
+ function createPaginatedResponse(data, total, page, limit) {
62
+ return NextResponse.json({
63
+ success: true,
64
+ data: {
65
+ data,
66
+ pagination: {
67
+ total,
68
+ page,
69
+ limit,
70
+ totalPages: Math.ceil(total / limit),
71
+ hasMore: page * limit < total
72
+ }
73
+ }
74
+ });
75
+ }
76
+ function requireAdmin(userRole) {
77
+ if (userRole !== "ADMIN") {
78
+ return {
79
+ isAdmin: false,
80
+ response: NextResponse.json(
81
+ {
82
+ success: false,
83
+ error: {
84
+ code: 40301,
85
+ message: "Admin access required"
86
+ }
87
+ },
88
+ { status: 403 }
89
+ )
90
+ };
91
+ }
92
+ return { isAdmin: true };
93
+ }
94
+ async function parseRequestBody(req) {
95
+ try {
96
+ const data = await req.json();
97
+ return { success: true, data };
98
+ } catch (error) {
99
+ return {
100
+ success: false,
101
+ response: NextResponse.json(
102
+ {
103
+ success: false,
104
+ error: {
105
+ code: 40001,
106
+ message: "Invalid JSON body"
107
+ }
108
+ },
109
+ { status: 400 }
110
+ )
111
+ };
112
+ }
113
+ }
114
+ function getUserAgent(req) {
115
+ return req.headers.get("user-agent") || "unknown";
116
+ }
117
+ function getReferer(req) {
118
+ return req.headers.get("referer");
119
+ }
120
+ function getSearchParam(req, key, defaultValue) {
121
+ const { searchParams } = new URL(req.url);
122
+ return searchParams.get(key) || defaultValue;
123
+ }
124
+ function parseBooleanParam(req, key, defaultValue) {
125
+ const { searchParams } = new URL(req.url);
126
+ const value = searchParams.get(key);
127
+ if (value === null) {
128
+ return defaultValue;
129
+ }
130
+ return value === "true" || value === "1";
131
+ }
132
+ function parseNumberParam(req, key, defaultValue) {
133
+ const { searchParams } = new URL(req.url);
134
+ const value = searchParams.get(key);
135
+ if (value === null) {
136
+ return defaultValue;
137
+ }
138
+ const parsed = parseInt(value, 10);
139
+ return isNaN(parsed) ? defaultValue : parsed;
140
+ }
141
+
142
+ export {
143
+ validateAndParse,
144
+ parsePagination,
145
+ parseSort,
146
+ parseFilters,
147
+ createPaginatedResponse,
148
+ requireAdmin,
149
+ parseRequestBody,
150
+ getUserAgent,
151
+ getReferer,
152
+ getSearchParam,
153
+ parseBooleanParam,
154
+ parseNumberParam
155
+ };
@@ -0,0 +1,93 @@
1
+ // src/constants/messages.ts
2
+ var GENERIC_ERROR_MESSAGES = {
3
+ // 인증 관련 (범용)
4
+ AUTH: {
5
+ UNAUTHORIZED: "Authentication required",
6
+ INVALID_TOKEN: "Invalid or expired token",
7
+ TOKEN_EXPIRED: "Token has expired",
8
+ INVALID_CREDENTIALS: "Invalid email or password",
9
+ EMAIL_NOT_VERIFIED: "Email verification required",
10
+ ACCOUNT_DISABLED: "Account is disabled",
11
+ ADMIN_REQUIRED: "Admin privileges required",
12
+ PASSWORD_NOT_SET: "Password not set. Please use OAuth login or set a password first."
13
+ },
14
+ // 리소스 관련 (범용)
15
+ RESOURCE: {
16
+ NOT_FOUND: "Resource not found",
17
+ USER_NOT_FOUND: "User not found"
18
+ },
19
+ // 검증 관련 (범용)
20
+ VALIDATION: {
21
+ INVALID_INPUT: "Invalid input data",
22
+ REQUIRED_FIELD: "This field is required",
23
+ INVALID_EMAIL: "Please enter a valid email address",
24
+ INVALID_URL: "Please enter a valid URL",
25
+ PASSWORD_TOO_SHORT: "Password must be at least 8 characters",
26
+ PASSWORD_TOO_LONG: "Password must be 128 characters or less",
27
+ PASSWORD_REQUIRED: "Password is required",
28
+ INVALID_FORMAT: "Invalid format"
29
+ },
30
+ // 서버 관련 (범용)
31
+ SERVER: {
32
+ INTERNAL_ERROR: "Internal server error",
33
+ SERVER_ERROR: "Server error occurred",
34
+ DATABASE_ERROR: "Database error occurred",
35
+ EXTERNAL_SERVICE_ERROR: "External service unavailable",
36
+ SERVICE_UNAVAILABLE: "Service temporarily unavailable"
37
+ },
38
+ // Rate Limiting (범용)
39
+ RATE_LIMIT: {
40
+ EXCEEDED: "Too many requests. Please try again later.",
41
+ TRY_AGAIN_LATER: "Please try again in {seconds} seconds"
42
+ },
43
+ // 보안 (범용)
44
+ SECURITY: {
45
+ CORS_VIOLATION: "CORS policy violation",
46
+ CSRF_VALIDATION_FAILED: "CSRF validation failed",
47
+ FORBIDDEN: "Access denied"
48
+ }
49
+ };
50
+ var GENERIC_SUCCESS_MESSAGES = {
51
+ // 인증 관련 (범용)
52
+ AUTH: {
53
+ LOGIN_SUCCESS: "Login successful",
54
+ LOGOUT_SUCCESS: "Logout successful",
55
+ REGISTER_SUCCESS: "Registration successful",
56
+ PASSWORD_CHANGED: "Password changed successfully",
57
+ EMAIL_VERIFIED: "Email verified successfully",
58
+ PASSWORD_RESET_SENT: "Password reset email sent"
59
+ },
60
+ // 리소스 관련 (범용)
61
+ RESOURCE: {
62
+ CREATED: "Resource created successfully",
63
+ UPDATED: "Resource updated successfully",
64
+ DELETED: "Resource deleted successfully"
65
+ },
66
+ // 일반 (범용)
67
+ GENERAL: {
68
+ OPERATION_SUCCESS: "Operation completed successfully",
69
+ SAVED: "Changes saved successfully",
70
+ SENT: "Sent successfully"
71
+ }
72
+ };
73
+ var GENERIC_CONFIRM_MESSAGES = {
74
+ DELETE: "Are you sure you want to delete this?",
75
+ LOGOUT: "Are you sure you want to logout?",
76
+ DISCARD_CHANGES: "Are you sure you want to discard changes?",
77
+ DEACTIVATE: "Are you sure you want to deactivate this?"
78
+ };
79
+ var GENERIC_INFO_MESSAGES = {
80
+ NO_DATA: "No data available",
81
+ LOADING: "Loading...",
82
+ PROCESSING: "Processing...",
83
+ PLEASE_WAIT: "Please wait...",
84
+ NO_RESULTS: "No results found",
85
+ EMPTY_LIST: "The list is empty"
86
+ };
87
+
88
+ export {
89
+ GENERIC_ERROR_MESSAGES,
90
+ GENERIC_SUCCESS_MESSAGES,
91
+ GENERIC_CONFIRM_MESSAGES,
92
+ GENERIC_INFO_MESSAGES
93
+ };
@@ -0,0 +1,117 @@
1
+ import {
2
+ cn
3
+ } from "./chunk-62FLBG6B.js";
4
+
5
+ // src/components/ui/loading-bar.tsx
6
+ import { useEffect, useState } from "react";
7
+ import { jsx, jsxs } from "react/jsx-runtime";
8
+ function LoadingBar({
9
+ className,
10
+ size = "md",
11
+ variant = "default",
12
+ animated = true
13
+ }) {
14
+ const [progress, setProgress] = useState(0);
15
+ useEffect(() => {
16
+ if (!animated) return;
17
+ const interval = setInterval(() => {
18
+ setProgress((prev) => {
19
+ if (prev >= 100) {
20
+ return 0;
21
+ }
22
+ return prev + Math.random() * 15;
23
+ });
24
+ }, 200);
25
+ return () => clearInterval(interval);
26
+ }, [animated]);
27
+ const sizeClasses = {
28
+ sm: "h-1",
29
+ md: "h-2",
30
+ lg: "h-3"
31
+ };
32
+ const variantClasses = {
33
+ default: "bg-gradient-to-r from-blue-500 via-purple-500 to-pink-500",
34
+ primary: "bg-gradient-to-r from-blue-600 via-blue-500 to-blue-400",
35
+ secondary: "bg-gradient-to-r from-gray-600 via-gray-500 to-gray-400"
36
+ };
37
+ return /* @__PURE__ */ jsxs("div", { className: cn(
38
+ "w-full bg-gray-200 dark:bg-gray-700 rounded-full overflow-hidden",
39
+ sizeClasses[size],
40
+ className
41
+ ), children: [
42
+ /* @__PURE__ */ jsx(
43
+ "div",
44
+ {
45
+ className: cn(
46
+ "h-full rounded-full transition-all duration-300 ease-out",
47
+ variantClasses[variant]
48
+ ),
49
+ style: {
50
+ width: animated ? `${Math.min(progress, 100)}%` : "100%",
51
+ backgroundSize: "200% 100%",
52
+ animation: animated ? "shimmer 2s ease-in-out infinite" : "none"
53
+ }
54
+ }
55
+ ),
56
+ animated && /* @__PURE__ */ jsx("style", { dangerouslySetInnerHTML: {
57
+ __html: `
58
+ @keyframes shimmer {
59
+ 0% { background-position: -200% 0; }
60
+ 100% { background-position: 200% 0; }
61
+ }
62
+ `
63
+ } })
64
+ ] });
65
+ }
66
+ function LoadingBarWithText({
67
+ className,
68
+ size = "md",
69
+ variant = "default",
70
+ text = "Loading data...",
71
+ animated = true
72
+ }) {
73
+ return /* @__PURE__ */ jsxs("div", { className: cn("flex flex-col items-center space-y-3 py-8", className), children: [
74
+ /* @__PURE__ */ jsx(LoadingBar, { size, variant, className: "w-64", animated }),
75
+ /* @__PURE__ */ jsx("p", { className: "text-sm text-gray-500 dark:text-gray-400 animate-pulse", children: text })
76
+ ] });
77
+ }
78
+ function LoadingBarCompact({
79
+ className,
80
+ size = "sm",
81
+ variant = "primary",
82
+ animated = true
83
+ }) {
84
+ return /* @__PURE__ */ jsxs("div", { className: cn("flex items-center space-x-2", className), children: [
85
+ /* @__PURE__ */ jsx(LoadingBar, { size, variant, className: "flex-1", animated }),
86
+ animated && /* @__PURE__ */ jsx("div", { className: "w-2 h-2 bg-blue-600 rounded-full animate-ping" })
87
+ ] });
88
+ }
89
+ function LoadingCard({
90
+ variant = "card",
91
+ text = "Loading...",
92
+ className,
93
+ size = "md",
94
+ animated = true
95
+ }) {
96
+ switch (variant) {
97
+ case "bar":
98
+ return /* @__PURE__ */ jsx(LoadingBar, { size, className, animated });
99
+ case "compact":
100
+ return /* @__PURE__ */ jsx(LoadingBarCompact, { size, className, animated });
101
+ case "text":
102
+ return /* @__PURE__ */ jsx(LoadingBarWithText, { text, size, className, animated });
103
+ case "card":
104
+ default:
105
+ return /* @__PURE__ */ jsx("div", { className: cn("bg-white border border-gray-200 rounded-lg shadow-sm", className), children: /* @__PURE__ */ jsx("div", { className: "p-6", children: /* @__PURE__ */ jsxs("div", { className: "py-8 text-center text-gray-500", children: [
106
+ /* @__PURE__ */ jsx(LoadingBarCompact, { size: "sm", className: "mb-4", animated }),
107
+ /* @__PURE__ */ jsx("p", { className: "text-sm", children: text })
108
+ ] }) }) });
109
+ }
110
+ }
111
+
112
+ export {
113
+ LoadingBar,
114
+ LoadingBarWithText,
115
+ LoadingBarCompact,
116
+ LoadingCard
117
+ };
@@ -0,0 +1,120 @@
1
+ import {
2
+ getErrorDisplayInfo,
3
+ getFriendlyMessage
4
+ } from "./chunk-2DVWSDST.js";
5
+ import {
6
+ getErrorCategory
7
+ } from "./chunk-Y3OTJH2S.js";
8
+
9
+ // src/error/error-display.ts
10
+ import { toast } from "sonner";
11
+ function getLocale() {
12
+ var _a;
13
+ if (typeof window === "undefined") return "ko";
14
+ const locale = localStorage.getItem("locale") || ((_a = document.cookie.match(/locale=([^;]+)/)) == null ? void 0 : _a[1]);
15
+ return locale === "en" ? "en" : "ko";
16
+ }
17
+ function showFriendlyError(errorOrCode, options) {
18
+ var _a;
19
+ const { locale = getLocale(), duration = 5e3, showCode = true, onAuthError, onRateLimitError } = options || {};
20
+ let code;
21
+ let displayInfo;
22
+ if (typeof errorOrCode === "number") {
23
+ code = errorOrCode;
24
+ displayInfo = getErrorDisplayInfo(code, locale);
25
+ } else if (errorOrCode instanceof Error) {
26
+ if ("code" in errorOrCode && typeof errorOrCode.code === "number") {
27
+ code = errorOrCode.code;
28
+ } else {
29
+ code = 50002;
30
+ }
31
+ displayInfo = getErrorDisplayInfo(code, locale);
32
+ } else {
33
+ code = ((_a = errorOrCode.error) == null ? void 0 : _a.code) || 50002;
34
+ displayInfo = getErrorDisplayInfo(code, locale);
35
+ }
36
+ const category = getErrorCategory(code);
37
+ if (category === "auth" && onAuthError) onAuthError();
38
+ if (category === "rateLimit" && onRateLimitError) onRateLimitError();
39
+ const description = showCode ? `${displayInfo.description} [${code}]` : displayInfo.description;
40
+ switch (displayInfo.severity) {
41
+ case "critical":
42
+ case "error":
43
+ toast.error(displayInfo.title, { description, duration });
44
+ break;
45
+ case "warning":
46
+ toast.warning(displayInfo.title, { description, duration });
47
+ break;
48
+ case "info":
49
+ default:
50
+ toast.info(displayInfo.title, { description, duration });
51
+ }
52
+ }
53
+ async function handleApiResponse(response, options) {
54
+ var _a;
55
+ if (response.ok) {
56
+ const data = await response.json();
57
+ return data.data;
58
+ }
59
+ const errorData = await response.json();
60
+ if ((options == null ? void 0 : options.showToast) !== false) {
61
+ showFriendlyError(errorData, {
62
+ locale: options == null ? void 0 : options.locale,
63
+ onAuthError: options == null ? void 0 : options.onAuthError
64
+ });
65
+ }
66
+ throw new Error(((_a = errorData.error) == null ? void 0 : _a.message) || `Request failed with status ${response.status}`);
67
+ }
68
+ function formatInlineError(code, locale) {
69
+ const lang = locale || getLocale();
70
+ const { title, description } = getFriendlyMessage(code, lang);
71
+ return `${description} [${code}]`;
72
+ }
73
+ function getErrorIcon(code) {
74
+ const category = getErrorCategory(code);
75
+ const icons = {
76
+ validation: "\u26A0\uFE0F",
77
+ auth: "\u{1F510}",
78
+ permission: "\u{1F6AB}",
79
+ resource: "\u{1F50D}",
80
+ conflict: "\u26A1",
81
+ business: "\u{1F4CB}",
82
+ rateLimit: "\u23F1\uFE0F",
83
+ server: "\u{1F527}",
84
+ security: "\u{1F6E1}\uFE0F",
85
+ unknown: "\u274C"
86
+ };
87
+ return icons[category] || "\u274C";
88
+ }
89
+ function getDefaultErrorCode(status) {
90
+ const statusMap = {
91
+ 400: 40002,
92
+ 401: 40101,
93
+ 403: 40304,
94
+ 404: 40401,
95
+ 409: 40904,
96
+ 422: 42201,
97
+ 429: 42901,
98
+ 500: 50002,
99
+ 503: 50305
100
+ };
101
+ return statusMap[status] || 50002;
102
+ }
103
+ function extractErrorInfo(error) {
104
+ if (error instanceof Error) {
105
+ if ("code" in error && typeof error.code === "number" && error.code >= 1e4) {
106
+ return { code: error.code, message: error.message, stack: error.stack };
107
+ }
108
+ return { code: 50001, message: error.message, stack: error.stack };
109
+ }
110
+ return { code: 50001, message: String(error) };
111
+ }
112
+
113
+ export {
114
+ showFriendlyError,
115
+ handleApiResponse,
116
+ formatInlineError,
117
+ getErrorIcon,
118
+ getDefaultErrorCode,
119
+ extractErrorInfo
120
+ };