@payez/next-mvp 4.0.1 → 4.0.2

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 (433) hide show
  1. package/dist/api/auth-handler.d.ts +66 -0
  2. package/dist/api/auth-handler.js +397 -0
  3. package/dist/api/index.d.ts +10 -0
  4. package/dist/api/index.js +19 -0
  5. package/dist/api-handlers/account/change-password.d.ts +9 -0
  6. package/dist/api-handlers/account/change-password.js +110 -0
  7. package/dist/api-handlers/account/masked-info.d.ts +2 -0
  8. package/dist/api-handlers/account/masked-info.js +41 -0
  9. package/dist/api-handlers/account/profile.d.ts +3 -0
  10. package/dist/api-handlers/account/profile.js +63 -0
  11. package/dist/api-handlers/account/recovery/initiate.d.ts +2 -0
  12. package/dist/api-handlers/account/recovery/initiate.js +26 -0
  13. package/dist/api-handlers/account/recovery/send-code.d.ts +2 -0
  14. package/dist/api-handlers/account/recovery/send-code.js +28 -0
  15. package/dist/api-handlers/account/recovery/verify-code.d.ts +2 -0
  16. package/dist/api-handlers/account/recovery/verify-code.js +28 -0
  17. package/dist/api-handlers/account/reset-password.d.ts +2 -0
  18. package/dist/api-handlers/account/reset-password.js +26 -0
  19. package/dist/api-handlers/account/send-code.d.ts +24 -0
  20. package/dist/api-handlers/account/send-code.js +60 -0
  21. package/dist/api-handlers/account/update-phone.d.ts +27 -0
  22. package/dist/api-handlers/account/update-phone.js +64 -0
  23. package/dist/api-handlers/account/validate-password.d.ts +17 -0
  24. package/dist/api-handlers/account/validate-password.js +81 -0
  25. package/dist/api-handlers/account/verify-email.d.ts +26 -0
  26. package/dist/api-handlers/account/verify-email.js +106 -0
  27. package/dist/api-handlers/account/verify-sms.d.ts +26 -0
  28. package/dist/api-handlers/account/verify-sms.js +106 -0
  29. package/dist/api-handlers/admin/analytics.d.ts +19 -0
  30. package/dist/api-handlers/admin/analytics.js +378 -0
  31. package/dist/api-handlers/admin/audit.d.ts +19 -0
  32. package/dist/api-handlers/admin/audit.js +213 -0
  33. package/dist/api-handlers/admin/index.d.ts +21 -0
  34. package/dist/api-handlers/admin/index.js +42 -0
  35. package/dist/api-handlers/admin/redis-sessions.d.ts +35 -0
  36. package/dist/api-handlers/admin/redis-sessions.js +203 -0
  37. package/dist/api-handlers/admin/sessions.d.ts +20 -0
  38. package/dist/api-handlers/admin/sessions.js +283 -0
  39. package/dist/api-handlers/admin/site-logs.d.ts +45 -0
  40. package/dist/api-handlers/admin/site-logs.js +317 -0
  41. package/dist/api-handlers/admin/stats.d.ts +20 -0
  42. package/dist/api-handlers/admin/stats.js +239 -0
  43. package/dist/api-handlers/admin/users.d.ts +19 -0
  44. package/dist/api-handlers/admin/users.js +221 -0
  45. package/dist/api-handlers/admin/vibe-data.d.ts +79 -0
  46. package/dist/api-handlers/admin/vibe-data.js +267 -0
  47. package/dist/api-handlers/anon/preferences.d.ts +37 -0
  48. package/dist/api-handlers/anon/preferences.js +96 -0
  49. package/dist/api-handlers/auth/jwks.d.ts +2 -0
  50. package/dist/api-handlers/auth/jwks.js +24 -0
  51. package/dist/api-handlers/auth/login.d.ts +42 -0
  52. package/dist/api-handlers/auth/login.js +178 -0
  53. package/dist/api-handlers/auth/refresh.d.ts +74 -0
  54. package/dist/api-handlers/auth/refresh.js +633 -0
  55. package/dist/api-handlers/auth/signout.d.ts +37 -0
  56. package/dist/api-handlers/auth/signout.js +186 -0
  57. package/dist/api-handlers/auth/status.d.ts +8 -0
  58. package/dist/api-handlers/auth/status.js +23 -0
  59. package/dist/api-handlers/auth/update-session.d.ts +37 -0
  60. package/dist/api-handlers/auth/update-session.js +93 -0
  61. package/dist/api-handlers/auth/validate.d.ts +6 -0
  62. package/dist/api-handlers/auth/validate.js +43 -0
  63. package/dist/api-handlers/auth/verify-code.d.ts +43 -0
  64. package/dist/api-handlers/auth/verify-code.js +90 -0
  65. package/dist/api-handlers/session/refresh-viability.d.ts +14 -0
  66. package/dist/api-handlers/session/refresh-viability.js +39 -0
  67. package/dist/api-handlers/session/viability.d.ts +13 -0
  68. package/dist/api-handlers/session/viability.js +114 -0
  69. package/dist/api-handlers/test/force-expire.d.ts +23 -0
  70. package/dist/api-handlers/test/force-expire.js +59 -0
  71. package/dist/auth/auth-decision.d.ts +39 -0
  72. package/dist/auth/auth-decision.js +182 -0
  73. package/dist/auth/better-auth.d.ts +79 -0
  74. package/dist/auth/better-auth.js +119 -0
  75. package/dist/auth/route-config.d.ts +66 -0
  76. package/dist/auth/route-config.js +190 -0
  77. package/dist/auth/types/auth-types.d.ts +417 -0
  78. package/dist/auth/types/auth-types.js +53 -0
  79. package/dist/auth/types/index.d.ts +6 -0
  80. package/dist/auth/types/index.js +22 -0
  81. package/dist/auth/unauthenticated-routes.d.ts +1 -0
  82. package/dist/auth/unauthenticated-routes.js +19 -0
  83. package/dist/auth/utils/idp-client.d.ts +94 -0
  84. package/dist/auth/utils/idp-client.js +384 -0
  85. package/dist/auth/utils/index.d.ts +5 -0
  86. package/dist/auth/utils/index.js +21 -0
  87. package/dist/auth/utils/token-utils.d.ts +83 -0
  88. package/dist/auth/utils/token-utils.js +218 -0
  89. package/dist/client/AuthContext.d.ts +19 -0
  90. package/dist/client/AuthContext.js +115 -0
  91. package/dist/client/better-auth-client.d.ts +1020 -0
  92. package/dist/client/better-auth-client.js +68 -0
  93. package/dist/client/fetch-with-auth.d.ts +11 -0
  94. package/dist/client/fetch-with-auth.js +44 -0
  95. package/dist/client/fetchWithSession.d.ts +3 -0
  96. package/dist/client/fetchWithSession.js +24 -0
  97. package/dist/client/index.d.ts +9 -0
  98. package/dist/client/index.js +20 -0
  99. package/dist/client/useAnonSession.d.ts +36 -0
  100. package/dist/client/useAnonSession.js +99 -0
  101. package/dist/components/SessionSync.d.ts +13 -0
  102. package/dist/components/SessionSync.js +121 -0
  103. package/dist/components/SignalRHealthCheck.d.ts +10 -0
  104. package/dist/components/SignalRHealthCheck.js +97 -0
  105. package/dist/components/account/MobileNavDrawer.d.ts +32 -0
  106. package/dist/components/account/MobileNavDrawer.js +81 -0
  107. package/dist/components/account/UserAvatarMenu.d.ts +20 -0
  108. package/dist/components/account/UserAvatarMenu.js +91 -0
  109. package/dist/components/account/index.d.ts +9 -0
  110. package/dist/components/account/index.js +13 -0
  111. package/dist/components/admin/AlertSettingsTab.d.ts +48 -0
  112. package/dist/components/admin/AlertSettingsTab.js +351 -0
  113. package/dist/components/admin/AnalyticsTab.d.ts +22 -0
  114. package/dist/components/admin/AnalyticsTab.js +167 -0
  115. package/dist/components/admin/DataBrowserTab.d.ts +19 -0
  116. package/dist/components/admin/DataBrowserTab.js +252 -0
  117. package/dist/components/admin/LoggingSettingsTab.d.ts +73 -0
  118. package/dist/components/admin/LoggingSettingsTab.js +339 -0
  119. package/dist/components/admin/SessionsTab.d.ts +37 -0
  120. package/dist/components/admin/SessionsTab.js +165 -0
  121. package/dist/components/admin/StatsTab.d.ts +53 -0
  122. package/dist/components/admin/StatsTab.js +161 -0
  123. package/dist/components/admin/VibeAdminContext.d.ts +32 -0
  124. package/dist/components/admin/VibeAdminContext.js +38 -0
  125. package/dist/components/admin/VibeAdminLayout.d.ts +11 -0
  126. package/dist/components/admin/VibeAdminLayout.js +71 -0
  127. package/dist/components/admin/index.d.ts +29 -0
  128. package/dist/components/admin/index.js +44 -0
  129. package/dist/components/auth/FederatedAuthSection.d.ts +8 -0
  130. package/dist/components/auth/FederatedAuthSection.js +45 -0
  131. package/dist/components/auth/ModeAwareLoginPage.d.ts +10 -0
  132. package/dist/components/auth/ModeAwareLoginPage.js +42 -0
  133. package/dist/components/auth/ModeAwareSignupPage.d.ts +9 -0
  134. package/dist/components/auth/ModeAwareSignupPage.js +78 -0
  135. package/dist/components/auth/TraditionalAuthSection.d.ts +14 -0
  136. package/dist/components/auth/TraditionalAuthSection.js +20 -0
  137. package/dist/components/recovery/CompleteStep.d.ts +5 -0
  138. package/dist/components/recovery/CompleteStep.js +8 -0
  139. package/dist/components/recovery/InitiateRecoveryStep.d.ts +8 -0
  140. package/dist/components/recovery/InitiateRecoveryStep.js +20 -0
  141. package/dist/components/recovery/SelectMethodStep.d.ts +8 -0
  142. package/dist/components/recovery/SelectMethodStep.js +8 -0
  143. package/dist/components/recovery/SetPasswordStep.d.ts +6 -0
  144. package/dist/components/recovery/SetPasswordStep.js +20 -0
  145. package/dist/components/recovery/VerifyCodeStep.d.ts +10 -0
  146. package/dist/components/recovery/VerifyCodeStep.js +24 -0
  147. package/dist/components/reserved/ReservedRecoveryWarning.d.ts +38 -0
  148. package/dist/components/reserved/ReservedRecoveryWarning.js +92 -0
  149. package/dist/components/reserved/ReservedStatusBox.d.ts +30 -0
  150. package/dist/components/reserved/ReservedStatusBox.js +71 -0
  151. package/dist/components/ui/BetaBadge.d.ts +29 -0
  152. package/dist/components/ui/BetaBadge.js +38 -0
  153. package/dist/components/ui/Footer.d.ts +37 -0
  154. package/dist/components/ui/Footer.js +41 -0
  155. package/dist/config/env.d.ts +66 -0
  156. package/dist/config/env.js +57 -0
  157. package/dist/config/logger.d.ts +57 -0
  158. package/dist/config/logger.js +73 -0
  159. package/dist/config/logging-config.d.ts +30 -0
  160. package/dist/config/logging-config.js +122 -0
  161. package/dist/config/unauthenticated-routes.d.ts +17 -0
  162. package/dist/config/unauthenticated-routes.js +24 -0
  163. package/dist/config/vibe-log-transport.d.ts +81 -0
  164. package/dist/config/vibe-log-transport.js +212 -0
  165. package/dist/edge/internal-api-url.d.ts +53 -0
  166. package/dist/edge/internal-api-url.js +63 -0
  167. package/dist/edge/middleware.d.ts +14 -0
  168. package/dist/edge/middleware.js +32 -0
  169. package/dist/hooks/useAuth.d.ts +23 -0
  170. package/dist/hooks/useAuth.js +83 -0
  171. package/dist/hooks/useAuthSettings.d.ts +59 -0
  172. package/dist/hooks/useAuthSettings.js +93 -0
  173. package/dist/hooks/useAvailableProviders.d.ts +43 -0
  174. package/dist/hooks/useAvailableProviders.js +112 -0
  175. package/dist/hooks/usePasswordValidation.d.ts +27 -0
  176. package/dist/hooks/usePasswordValidation.js +102 -0
  177. package/dist/hooks/useProfile.d.ts +15 -0
  178. package/dist/hooks/useProfile.js +59 -0
  179. package/dist/hooks/usePublicAuthSettings.d.ts +56 -0
  180. package/dist/hooks/usePublicAuthSettings.js +131 -0
  181. package/dist/hooks/useSessionExpiration.d.ts +56 -0
  182. package/dist/hooks/useSessionExpiration.js +72 -0
  183. package/dist/hooks/useViabilitySession.d.ts +75 -0
  184. package/dist/hooks/useViabilitySession.js +269 -0
  185. package/dist/index.d.ts +12 -0
  186. package/dist/index.js +53 -0
  187. package/dist/lib/anon-session.d.ts +74 -0
  188. package/dist/lib/anon-session.js +169 -0
  189. package/dist/lib/api-handler.d.ts +123 -0
  190. package/dist/lib/api-handler.js +478 -0
  191. package/dist/lib/app-slug.d.ts +95 -0
  192. package/dist/lib/app-slug.js +172 -0
  193. package/dist/lib/demo-mode.d.ts +6 -0
  194. package/dist/lib/demo-mode.js +16 -0
  195. package/dist/lib/geolocation.d.ts +64 -0
  196. package/dist/lib/geolocation.js +235 -0
  197. package/dist/lib/idp-client-config.d.ts +75 -0
  198. package/dist/lib/idp-client-config.js +425 -0
  199. package/dist/lib/idp-fetch.d.ts +14 -0
  200. package/dist/lib/idp-fetch.js +91 -0
  201. package/dist/lib/internal-api.d.ts +87 -0
  202. package/dist/lib/internal-api.js +122 -0
  203. package/dist/lib/jwt-decode-client.d.ts +10 -0
  204. package/dist/lib/jwt-decode-client.js +46 -0
  205. package/dist/lib/jwt-decode.d.ts +48 -0
  206. package/dist/lib/jwt-decode.js +57 -0
  207. package/dist/lib/rate-limit-service.d.ts +23 -0
  208. package/dist/lib/rate-limit-service.js +6 -0
  209. package/dist/lib/redis.d.ts +5 -0
  210. package/dist/lib/redis.js +28 -0
  211. package/dist/lib/refresh-token-validator.d.ts +13 -0
  212. package/dist/lib/refresh-token-validator.js +117 -0
  213. package/dist/lib/roles.d.ts +145 -0
  214. package/dist/lib/roles.js +168 -0
  215. package/dist/lib/secret-validation.d.ts +4 -0
  216. package/dist/lib/secret-validation.js +14 -0
  217. package/dist/lib/session-store.d.ts +170 -0
  218. package/dist/lib/session-store.js +545 -0
  219. package/dist/lib/session.d.ts +21 -0
  220. package/dist/lib/session.js +26 -0
  221. package/dist/lib/site-logger.d.ts +214 -0
  222. package/dist/lib/site-logger.js +210 -0
  223. package/dist/lib/standardized-client-api.d.ts +161 -0
  224. package/dist/lib/standardized-client-api.js +791 -0
  225. package/dist/lib/startup-init.d.ts +40 -0
  226. package/dist/lib/startup-init.js +257 -0
  227. package/dist/lib/test-aware-get-token.d.ts +2 -0
  228. package/dist/lib/test-aware-get-token.js +86 -0
  229. package/dist/lib/token-expiry.d.ts +14 -0
  230. package/dist/lib/token-expiry.js +39 -0
  231. package/dist/lib/token-lifecycle.d.ts +78 -0
  232. package/dist/lib/token-lifecycle.js +360 -0
  233. package/dist/lib/types/api-responses.d.ts +128 -0
  234. package/dist/lib/types/api-responses.js +171 -0
  235. package/dist/lib/user-agent-parser.d.ts +50 -0
  236. package/dist/lib/user-agent-parser.js +220 -0
  237. package/dist/logging/api/admin-analytics.d.ts +3 -0
  238. package/dist/logging/api/admin-analytics.js +45 -0
  239. package/dist/logging/api/audit-log.d.ts +3 -0
  240. package/dist/logging/api/audit-log.js +52 -0
  241. package/dist/logging/components/AdminAnalyticsLayout.d.ts +10 -0
  242. package/dist/logging/components/AdminAnalyticsLayout.js +11 -0
  243. package/dist/logging/components/AuditLogViewer.d.ts +7 -0
  244. package/dist/logging/components/AuditLogViewer.js +51 -0
  245. package/dist/logging/components/ErrorMetricsCard.d.ts +7 -0
  246. package/dist/logging/components/ErrorMetricsCard.js +16 -0
  247. package/dist/logging/components/HealthMetricsCard.d.ts +7 -0
  248. package/dist/logging/components/HealthMetricsCard.js +19 -0
  249. package/dist/logging/hooks/useAdminAnalytics.d.ts +24 -0
  250. package/dist/logging/hooks/useAdminAnalytics.js +22 -0
  251. package/dist/logging/hooks/useAuditLog.d.ts +6 -0
  252. package/dist/logging/hooks/useAuditLog.js +25 -0
  253. package/dist/logging/hooks/useErrorMetrics.d.ts +6 -0
  254. package/dist/logging/hooks/useErrorMetrics.js +38 -0
  255. package/dist/logging/hooks/useHealthMetrics.d.ts +6 -0
  256. package/dist/logging/hooks/useHealthMetrics.js +41 -0
  257. package/dist/logging/index.d.ts +11 -0
  258. package/dist/logging/index.js +40 -0
  259. package/dist/logging/types/analytics.d.ts +68 -0
  260. package/dist/logging/types/analytics.js +3 -0
  261. package/dist/logging/types/audit.d.ts +29 -0
  262. package/dist/logging/types/audit.js +2 -0
  263. package/dist/logging/types/index.d.ts +2 -0
  264. package/dist/logging/types/index.js +19 -0
  265. package/dist/middleware/auth-decision.d.ts +33 -0
  266. package/dist/middleware/auth-decision.js +65 -0
  267. package/dist/middleware/create-middleware.d.ts +102 -0
  268. package/dist/middleware/create-middleware.js +469 -0
  269. package/dist/middleware/rbac-check.d.ts +51 -0
  270. package/dist/middleware/rbac-check.js +219 -0
  271. package/dist/middleware/twofa-presets.d.ts +134 -0
  272. package/dist/middleware/twofa-presets.js +175 -0
  273. package/dist/models/DecodedAccessToken.d.ts +17 -0
  274. package/dist/models/DecodedAccessToken.js +2 -0
  275. package/dist/models/SessionModel.d.ts +122 -0
  276. package/dist/models/SessionModel.js +136 -0
  277. package/dist/pages/admin-login/page.d.ts +31 -0
  278. package/dist/pages/admin-login/page.js +73 -0
  279. package/dist/pages/admin-page-permissions/PagePermissionsAdminPage.d.ts +18 -0
  280. package/dist/pages/admin-page-permissions/PagePermissionsAdminPage.js +276 -0
  281. package/dist/pages/admin-page-permissions/index.d.ts +6 -0
  282. package/dist/pages/admin-page-permissions/index.js +13 -0
  283. package/dist/pages/admin-roles/RolesAdminPage.d.ts +16 -0
  284. package/dist/pages/admin-roles/RolesAdminPage.js +261 -0
  285. package/dist/pages/admin-roles/index.d.ts +8 -0
  286. package/dist/pages/admin-roles/index.js +15 -0
  287. package/dist/pages/admin-roles/modals.d.ts +72 -0
  288. package/dist/pages/admin-roles/modals.js +154 -0
  289. package/dist/pages/client-admin/ClientSiteAdminPage.d.ts +79 -0
  290. package/dist/pages/client-admin/ClientSiteAdminPage.js +179 -0
  291. package/dist/pages/client-admin/index.d.ts +32 -0
  292. package/dist/pages/client-admin/index.js +37 -0
  293. package/dist/pages/coming-soon/page.d.ts +8 -0
  294. package/dist/pages/coming-soon/page.js +28 -0
  295. package/dist/pages/login/page.d.ts +22 -0
  296. package/dist/pages/login/page.js +230 -0
  297. package/dist/pages/profile/EnhancedProfilePage.d.ts +13 -0
  298. package/dist/pages/profile/EnhancedProfilePage.js +150 -0
  299. package/dist/pages/profile/index.d.ts +8 -0
  300. package/dist/pages/profile/index.js +16 -0
  301. package/dist/pages/profile/page.d.ts +19 -0
  302. package/dist/pages/profile/page.js +47 -0
  303. package/dist/pages/recovery/page.d.ts +1 -0
  304. package/dist/pages/recovery/page.js +142 -0
  305. package/dist/pages/roles/MyRolesPage.d.ts +24 -0
  306. package/dist/pages/roles/MyRolesPage.js +71 -0
  307. package/dist/pages/roles/components.d.ts +63 -0
  308. package/dist/pages/roles/components.js +108 -0
  309. package/dist/pages/roles/index.d.ts +8 -0
  310. package/dist/pages/roles/index.js +19 -0
  311. package/dist/pages/security/EnhancedSecurityPage.d.ts +14 -0
  312. package/dist/pages/security/EnhancedSecurityPage.js +248 -0
  313. package/dist/pages/security/index.d.ts +8 -0
  314. package/dist/pages/security/index.js +16 -0
  315. package/dist/pages/security/page.d.ts +21 -0
  316. package/dist/pages/security/page.js +212 -0
  317. package/dist/pages/settings/EnhancedSettingsPage.d.ts +46 -0
  318. package/dist/pages/settings/EnhancedSettingsPage.js +231 -0
  319. package/dist/pages/settings/index.d.ts +8 -0
  320. package/dist/pages/settings/index.js +16 -0
  321. package/dist/pages/settings/page.d.ts +7 -0
  322. package/dist/pages/settings/page.js +26 -0
  323. package/dist/pages/showcase/ShowcasePage.d.ts +13 -0
  324. package/dist/pages/showcase/ShowcasePage.js +142 -0
  325. package/dist/pages/showcase/index.d.ts +12 -0
  326. package/dist/pages/showcase/index.js +17 -0
  327. package/dist/pages/test-env/EmergencyLogoutPage.d.ts +14 -0
  328. package/dist/pages/test-env/EmergencyLogoutPage.js +99 -0
  329. package/dist/pages/test-env/JwtInspectPage.d.ts +14 -0
  330. package/dist/pages/test-env/JwtInspectPage.js +116 -0
  331. package/dist/pages/test-env/RefreshTokenPage.d.ts +15 -0
  332. package/dist/pages/test-env/RefreshTokenPage.js +93 -0
  333. package/dist/pages/test-env/TestEnvPage.d.ts +13 -0
  334. package/dist/pages/test-env/TestEnvPage.js +51 -0
  335. package/dist/pages/test-env/index.d.ts +24 -0
  336. package/dist/pages/test-env/index.js +32 -0
  337. package/dist/pages/verify-code/page.d.ts +30 -0
  338. package/dist/pages/verify-code/page.js +412 -0
  339. package/dist/routes/account/index.d.ts +28 -0
  340. package/dist/routes/account/index.js +71 -0
  341. package/dist/routes/account/masked-info.d.ts +33 -0
  342. package/dist/routes/account/masked-info.js +39 -0
  343. package/dist/routes/account/send-code.d.ts +37 -0
  344. package/dist/routes/account/send-code.js +42 -0
  345. package/dist/routes/account/update-phone.d.ts +13 -0
  346. package/dist/routes/account/update-phone.js +17 -0
  347. package/dist/routes/account/verify-email.d.ts +38 -0
  348. package/dist/routes/account/verify-email.js +43 -0
  349. package/dist/routes/account/verify-sms.d.ts +38 -0
  350. package/dist/routes/account/verify-sms.js +43 -0
  351. package/dist/routes/auth/index.d.ts +19 -0
  352. package/dist/routes/auth/index.js +64 -0
  353. package/dist/routes/auth/logout.d.ts +31 -0
  354. package/dist/routes/auth/logout.js +98 -0
  355. package/dist/routes/auth/nextauth.d.ts +22 -0
  356. package/dist/routes/auth/nextauth.js +40 -0
  357. package/dist/routes/auth/refresh.d.ts +30 -0
  358. package/dist/routes/auth/refresh.js +51 -0
  359. package/dist/routes/auth/session.d.ts +43 -0
  360. package/dist/routes/auth/session.js +157 -0
  361. package/dist/routes/auth/settings.d.ts +25 -0
  362. package/dist/routes/auth/settings.js +55 -0
  363. package/dist/routes/auth/viability.d.ts +52 -0
  364. package/dist/routes/auth/viability.js +190 -0
  365. package/dist/routes/index.d.ts +12 -0
  366. package/dist/routes/index.js +54 -0
  367. package/dist/routes/session/index.d.ts +6 -0
  368. package/dist/routes/session/index.js +10 -0
  369. package/dist/routes/session/refresh-viability.d.ts +16 -0
  370. package/dist/routes/session/refresh-viability.js +20 -0
  371. package/dist/server/auth-guard.d.ts +46 -0
  372. package/dist/server/auth-guard.js +128 -0
  373. package/dist/server/auth.d.ts +50 -0
  374. package/dist/server/auth.js +62 -0
  375. package/dist/server/decode-session.d.ts +30 -0
  376. package/dist/server/decode-session.js +78 -0
  377. package/dist/server/slim-middleware.d.ts +23 -0
  378. package/dist/server/slim-middleware.js +89 -0
  379. package/dist/server/with-auth.d.ts +33 -0
  380. package/dist/server/with-auth.js +59 -0
  381. package/dist/services/signalrActivityService.d.ts +44 -0
  382. package/dist/services/signalrActivityService.js +257 -0
  383. package/dist/stores/authStore.d.ts +154 -0
  384. package/dist/stores/authStore.js +1527 -0
  385. package/dist/theme/ThemeProvider.d.ts +14 -0
  386. package/dist/theme/ThemeProvider.js +28 -0
  387. package/dist/theme/default.d.ts +8 -0
  388. package/dist/theme/default.js +33 -0
  389. package/dist/theme/index.d.ts +15 -0
  390. package/dist/theme/index.js +25 -0
  391. package/dist/theme/types.d.ts +56 -0
  392. package/dist/theme/types.js +8 -0
  393. package/dist/theme/useTheme.d.ts +60 -0
  394. package/dist/theme/useTheme.js +63 -0
  395. package/dist/theme/utils.d.ts +13 -0
  396. package/dist/theme/utils.js +39 -0
  397. package/dist/types/api.d.ts +134 -0
  398. package/dist/types/api.js +44 -0
  399. package/dist/types/auth.d.ts +19 -0
  400. package/dist/types/auth.js +2 -0
  401. package/dist/types/logging.d.ts +42 -0
  402. package/dist/types/logging.js +2 -0
  403. package/dist/types/recovery.d.ts +48 -0
  404. package/dist/types/recovery.js +2 -0
  405. package/dist/types/security.d.ts +1 -0
  406. package/dist/types/security.js +2 -0
  407. package/dist/utils/api.d.ts +85 -0
  408. package/dist/utils/api.js +287 -0
  409. package/dist/utils/circuitBreaker.d.ts +43 -0
  410. package/dist/utils/circuitBreaker.js +91 -0
  411. package/dist/utils/error-message.d.ts +1 -0
  412. package/dist/utils/error-message.js +103 -0
  413. package/dist/utils/layout/reservedSpace.d.ts +59 -0
  414. package/dist/utils/layout/reservedSpace.js +102 -0
  415. package/dist/utils/logout.d.ts +14 -0
  416. package/dist/utils/logout.js +32 -0
  417. package/dist/vibe/client.d.ts +261 -0
  418. package/dist/vibe/client.js +445 -0
  419. package/dist/vibe/enterprise-auth.d.ts +106 -0
  420. package/dist/vibe/enterprise-auth.js +173 -0
  421. package/dist/vibe/errors.d.ts +83 -0
  422. package/dist/vibe/errors.js +146 -0
  423. package/dist/vibe/generic.d.ts +234 -0
  424. package/dist/vibe/generic.js +369 -0
  425. package/dist/vibe/hooks/index.d.ts +169 -0
  426. package/dist/vibe/hooks/index.js +252 -0
  427. package/dist/vibe/index.d.ts +25 -0
  428. package/dist/vibe/index.js +72 -0
  429. package/dist/vibe/sessions.d.ts +161 -0
  430. package/dist/vibe/sessions.js +391 -0
  431. package/dist/vibe/types.d.ts +353 -0
  432. package/dist/vibe/types.js +315 -0
  433. package/package.json +1 -1
@@ -0,0 +1,50 @@
1
+ /**
2
+ * =============================================================================
3
+ * USER AGENT PARSER
4
+ * =============================================================================
5
+ *
6
+ * Lightweight user agent parsing without external dependencies.
7
+ * Extracts device type, browser, and OS information from user agent strings.
8
+ *
9
+ * USAGE:
10
+ * ------
11
+ * import { parseUserAgent, DeviceInfo } from '@payez/next-mvp/lib/user-agent-parser';
12
+ *
13
+ * const info = parseUserAgent(request.headers.get('user-agent'));
14
+ * console.log(info.browser); // 'Chrome'
15
+ * console.log(info.deviceType); // 'desktop'
16
+ *
17
+ * =============================================================================
18
+ */
19
+ export type DeviceType = 'desktop' | 'mobile' | 'tablet' | 'unknown';
20
+ export interface DeviceInfo {
21
+ deviceType: DeviceType;
22
+ browser: string;
23
+ browserVersion?: string;
24
+ os: string;
25
+ osVersion?: string;
26
+ isMobile: boolean;
27
+ isTablet: boolean;
28
+ isDesktop: boolean;
29
+ isBot: boolean;
30
+ raw: string;
31
+ }
32
+ /**
33
+ * Parse a user agent string to extract device, browser, and OS information.
34
+ *
35
+ * @param userAgent - The user agent string from request headers
36
+ * @returns Parsed device information
37
+ */
38
+ export declare function parseUserAgent(userAgent?: string | null): DeviceInfo;
39
+ /**
40
+ * Get a short, human-readable description of the device
41
+ */
42
+ export declare function getDeviceDescription(info: DeviceInfo): string;
43
+ /**
44
+ * Get device type icon (emoji)
45
+ */
46
+ export declare function getDeviceIcon(deviceType: DeviceType): string;
47
+ /**
48
+ * Get browser icon (emoji)
49
+ */
50
+ export declare function getBrowserIcon(browser: string): string;
@@ -0,0 +1,220 @@
1
+ "use strict";
2
+ /**
3
+ * =============================================================================
4
+ * USER AGENT PARSER
5
+ * =============================================================================
6
+ *
7
+ * Lightweight user agent parsing without external dependencies.
8
+ * Extracts device type, browser, and OS information from user agent strings.
9
+ *
10
+ * USAGE:
11
+ * ------
12
+ * import { parseUserAgent, DeviceInfo } from '@payez/next-mvp/lib/user-agent-parser';
13
+ *
14
+ * const info = parseUserAgent(request.headers.get('user-agent'));
15
+ * console.log(info.browser); // 'Chrome'
16
+ * console.log(info.deviceType); // 'desktop'
17
+ *
18
+ * =============================================================================
19
+ */
20
+ Object.defineProperty(exports, "__esModule", { value: true });
21
+ exports.parseUserAgent = parseUserAgent;
22
+ exports.getDeviceDescription = getDeviceDescription;
23
+ exports.getDeviceIcon = getDeviceIcon;
24
+ exports.getBrowserIcon = getBrowserIcon;
25
+ // -----------------------------------------------------------------------------
26
+ // DETECTION PATTERNS
27
+ // -----------------------------------------------------------------------------
28
+ const MOBILE_KEYWORDS = [
29
+ 'Mobile',
30
+ 'Android',
31
+ 'iPhone',
32
+ 'iPod',
33
+ 'BlackBerry',
34
+ 'IEMobile',
35
+ 'Opera Mini',
36
+ 'Opera Mobi',
37
+ 'Windows Phone',
38
+ ];
39
+ const TABLET_KEYWORDS = [
40
+ 'iPad',
41
+ 'Tablet',
42
+ 'PlayBook',
43
+ 'Silk',
44
+ 'Kindle',
45
+ ];
46
+ const BOT_KEYWORDS = [
47
+ 'bot',
48
+ 'spider',
49
+ 'crawler',
50
+ 'slurp',
51
+ 'googlebot',
52
+ 'bingbot',
53
+ 'yandex',
54
+ 'baidu',
55
+ 'duckduckbot',
56
+ 'facebookexternalhit',
57
+ 'twitterbot',
58
+ 'linkedinbot',
59
+ 'pinterest',
60
+ 'semrush',
61
+ 'ahref',
62
+ ];
63
+ // Browser detection patterns (order matters - more specific first)
64
+ const BROWSER_PATTERNS = [
65
+ { name: 'Edge', pattern: /Edg(?:e|A|iOS)?\/(\d+(?:\.\d+)*)/ },
66
+ { name: 'Opera', pattern: /(?:OPR|Opera)\/(\d+(?:\.\d+)*)/ },
67
+ { name: 'Samsung Browser', pattern: /SamsungBrowser\/(\d+(?:\.\d+)*)/ },
68
+ { name: 'UC Browser', pattern: /UCBrowser\/(\d+(?:\.\d+)*)/ },
69
+ { name: 'Firefox', pattern: /Firefox\/(\d+(?:\.\d+)*)/ },
70
+ { name: 'Chrome', pattern: /Chrome\/(\d+(?:\.\d+)*)/ },
71
+ { name: 'Safari', pattern: /Version\/(\d+(?:\.\d+)*).*Safari/ },
72
+ { name: 'Safari', pattern: /Safari\/(\d+(?:\.\d+)*)/ },
73
+ { name: 'IE', pattern: /(?:MSIE |rv:)(\d+(?:\.\d+)*)/ },
74
+ ];
75
+ // OS detection patterns
76
+ const OS_PATTERNS = [
77
+ { name: 'iOS', pattern: /iPhone|iPad|iPod/, versionPattern: /OS (\d+[_\.]\d+(?:[_\.]\d+)?)/ },
78
+ { name: 'Android', pattern: /Android/, versionPattern: /Android (\d+(?:\.\d+)*)/ },
79
+ { name: 'Windows', pattern: /Windows/, versionPattern: /Windows NT (\d+(?:\.\d+)*)/ },
80
+ { name: 'macOS', pattern: /Mac OS X/, versionPattern: /Mac OS X (\d+[_\.]\d+(?:[_\.]\d+)?)/ },
81
+ { name: 'Linux', pattern: /Linux/, versionPattern: undefined },
82
+ { name: 'Chrome OS', pattern: /CrOS/, versionPattern: undefined },
83
+ ];
84
+ // Windows NT version mapping
85
+ const WINDOWS_VERSIONS = {
86
+ '10.0': '10/11',
87
+ '6.3': '8.1',
88
+ '6.2': '8',
89
+ '6.1': '7',
90
+ '6.0': 'Vista',
91
+ '5.1': 'XP',
92
+ };
93
+ // -----------------------------------------------------------------------------
94
+ // PARSER FUNCTION
95
+ // -----------------------------------------------------------------------------
96
+ /**
97
+ * Parse a user agent string to extract device, browser, and OS information.
98
+ *
99
+ * @param userAgent - The user agent string from request headers
100
+ * @returns Parsed device information
101
+ */
102
+ function parseUserAgent(userAgent) {
103
+ const ua = userAgent || '';
104
+ const uaLower = ua.toLowerCase();
105
+ // Default result
106
+ const result = {
107
+ deviceType: 'unknown',
108
+ browser: 'Unknown',
109
+ os: 'Unknown',
110
+ isMobile: false,
111
+ isTablet: false,
112
+ isDesktop: false,
113
+ isBot: false,
114
+ raw: ua,
115
+ };
116
+ if (!ua)
117
+ return result;
118
+ // Check for bots first
119
+ result.isBot = BOT_KEYWORDS.some(keyword => uaLower.includes(keyword));
120
+ // Detect device type
121
+ result.isTablet = TABLET_KEYWORDS.some(keyword => ua.includes(keyword));
122
+ result.isMobile = !result.isTablet && MOBILE_KEYWORDS.some(keyword => ua.includes(keyword));
123
+ result.isDesktop = !result.isMobile && !result.isTablet && !result.isBot;
124
+ if (result.isTablet) {
125
+ result.deviceType = 'tablet';
126
+ }
127
+ else if (result.isMobile) {
128
+ result.deviceType = 'mobile';
129
+ }
130
+ else if (result.isDesktop) {
131
+ result.deviceType = 'desktop';
132
+ }
133
+ // Detect browser
134
+ for (const { name, pattern } of BROWSER_PATTERNS) {
135
+ const match = ua.match(pattern);
136
+ if (match) {
137
+ result.browser = name;
138
+ result.browserVersion = match[1];
139
+ break;
140
+ }
141
+ }
142
+ // Detect OS
143
+ for (const { name, pattern, versionPattern } of OS_PATTERNS) {
144
+ if (pattern.test(ua)) {
145
+ result.os = name;
146
+ if (versionPattern) {
147
+ const versionMatch = ua.match(versionPattern);
148
+ if (versionMatch) {
149
+ let version = versionMatch[1].replace(/_/g, '.');
150
+ // Map Windows NT versions to friendly names
151
+ if (name === 'Windows' && WINDOWS_VERSIONS[version]) {
152
+ version = WINDOWS_VERSIONS[version];
153
+ }
154
+ result.osVersion = version;
155
+ }
156
+ }
157
+ break;
158
+ }
159
+ }
160
+ return result;
161
+ }
162
+ // -----------------------------------------------------------------------------
163
+ // HELPER FUNCTIONS
164
+ // -----------------------------------------------------------------------------
165
+ /**
166
+ * Get a short, human-readable description of the device
167
+ */
168
+ function getDeviceDescription(info) {
169
+ const parts = [];
170
+ if (info.browser !== 'Unknown') {
171
+ parts.push(info.browser);
172
+ }
173
+ if (info.os !== 'Unknown') {
174
+ let osDesc = info.os;
175
+ if (info.osVersion) {
176
+ osDesc += ` ${info.osVersion}`;
177
+ }
178
+ parts.push(osDesc);
179
+ }
180
+ if (parts.length === 0) {
181
+ if (info.isBot)
182
+ return 'Bot';
183
+ return info.deviceType.charAt(0).toUpperCase() + info.deviceType.slice(1);
184
+ }
185
+ return parts.join(' / ');
186
+ }
187
+ /**
188
+ * Get device type icon (emoji)
189
+ */
190
+ function getDeviceIcon(deviceType) {
191
+ switch (deviceType) {
192
+ case 'mobile':
193
+ return '📱';
194
+ case 'tablet':
195
+ return '📲';
196
+ case 'desktop':
197
+ return '💻';
198
+ default:
199
+ return '🔌';
200
+ }
201
+ }
202
+ /**
203
+ * Get browser icon (emoji)
204
+ */
205
+ function getBrowserIcon(browser) {
206
+ const browserLower = browser.toLowerCase();
207
+ if (browserLower.includes('chrome'))
208
+ return '🌐';
209
+ if (browserLower.includes('firefox'))
210
+ return '🦊';
211
+ if (browserLower.includes('safari'))
212
+ return '🧭';
213
+ if (browserLower.includes('edge'))
214
+ return '🌐';
215
+ if (browserLower.includes('opera'))
216
+ return '🔴';
217
+ if (browserLower.includes('ie') || browserLower.includes('internet explorer'))
218
+ return '🌐';
219
+ return '🌐';
220
+ }
@@ -0,0 +1,3 @@
1
+ import { TimeRange } from '../types';
2
+ export declare function getErrorMetrics(timeRange?: TimeRange): Promise<any>;
3
+ export declare function getHealthMetrics(timeRange?: TimeRange): Promise<any>;
@@ -0,0 +1,45 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getErrorMetrics = getErrorMetrics;
4
+ exports.getHealthMetrics = getHealthMetrics;
5
+ const API_BASE = process.env.NEXT_PUBLIC_VIBE_API_URL || 'http://localhost:32786';
6
+ /**
7
+ * Get admin token from app's auth implementation
8
+ * Apps should override this via their own auth logic
9
+ */
10
+ function getAdminToken() {
11
+ if (typeof window !== 'undefined' && window.localStorage) {
12
+ return localStorage.getItem('admin_token') || '';
13
+ }
14
+ return '';
15
+ }
16
+ async function getErrorMetrics(timeRange = '24h') {
17
+ // Convert timeRange to hours for backend API
18
+ const hoursMap = {
19
+ '1h': 1,
20
+ '24h': 24,
21
+ '7d': 168,
22
+ '30d': 720
23
+ };
24
+ const hours = hoursMap[timeRange];
25
+ const res = await fetch(`${API_BASE}/v1/admin/analytics/errors?hours=${hours}`, {
26
+ headers: {
27
+ Authorization: `Bearer ${getAdminToken()}`
28
+ }
29
+ });
30
+ if (!res.ok) {
31
+ throw new Error(`Failed to fetch error metrics: ${res.statusText}`);
32
+ }
33
+ return res.json();
34
+ }
35
+ async function getHealthMetrics(timeRange = '1h') {
36
+ const res = await fetch(`${API_BASE}/v1/admin/analytics/health?timeRange=${timeRange}`, {
37
+ headers: {
38
+ Authorization: `Bearer ${getAdminToken()}`
39
+ }
40
+ });
41
+ if (!res.ok) {
42
+ throw new Error(`Failed to fetch health metrics: ${res.statusText}`);
43
+ }
44
+ return res.json();
45
+ }
@@ -0,0 +1,3 @@
1
+ import { AuditLogEntry, AuditLogQuery, AuditLogResponse } from '../types';
2
+ export declare function writeAuditLog(entry: Omit<AuditLogEntry, 'id' | 'timestamp'>): Promise<any>;
3
+ export declare function queryAuditLog(query: AuditLogQuery): Promise<AuditLogResponse>;
@@ -0,0 +1,52 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.writeAuditLog = writeAuditLog;
4
+ exports.queryAuditLog = queryAuditLog;
5
+ const API_BASE = process.env.NEXT_PUBLIC_VIBE_API_URL || 'http://localhost:32786';
6
+ /**
7
+ * Get admin token from app's auth implementation
8
+ */
9
+ function getAdminToken() {
10
+ if (typeof window !== 'undefined' && window.localStorage) {
11
+ return localStorage.getItem('admin_token') || '';
12
+ }
13
+ return '';
14
+ }
15
+ async function writeAuditLog(entry) {
16
+ const res = await fetch(`${API_BASE}/v1/audit`, {
17
+ method: 'POST',
18
+ headers: {
19
+ 'Content-Type': 'application/json',
20
+ Authorization: `Bearer ${getAdminToken()}`
21
+ },
22
+ body: JSON.stringify(entry)
23
+ });
24
+ if (!res.ok) {
25
+ throw new Error(`Failed to write audit log: ${res.statusText}`);
26
+ }
27
+ return res.json();
28
+ }
29
+ async function queryAuditLog(query) {
30
+ const params = new URLSearchParams();
31
+ if (query.category)
32
+ params.append('category', query.category);
33
+ if (query.userId)
34
+ params.append('userId', query.userId.toString());
35
+ if (query.startDate)
36
+ params.append('startDate', query.startDate);
37
+ if (query.endDate)
38
+ params.append('endDate', query.endDate);
39
+ if (query.page)
40
+ params.append('page', query.page.toString());
41
+ if (query.pageSize)
42
+ params.append('pageSize', query.pageSize.toString());
43
+ const res = await fetch(`${API_BASE}/v1/audit?${params.toString()}`, {
44
+ headers: {
45
+ Authorization: `Bearer ${getAdminToken()}`
46
+ }
47
+ });
48
+ if (!res.ok) {
49
+ throw new Error(`Failed to query audit log: ${res.statusText}`);
50
+ }
51
+ return res.json();
52
+ }
@@ -0,0 +1,10 @@
1
+ import { ReactNode } from 'react';
2
+ import { TimeRange } from '../types';
3
+ interface AdminAnalyticsLayoutProps {
4
+ title: string;
5
+ timeRange: TimeRange;
6
+ onTimeRangeChange: (range: TimeRange) => void;
7
+ children: ReactNode;
8
+ }
9
+ export declare function AdminAnalyticsLayout({ title, timeRange, onTimeRangeChange, children, }: AdminAnalyticsLayoutProps): import("react/jsx-runtime").JSX.Element;
10
+ export {};
@@ -0,0 +1,11 @@
1
+ "use strict";
2
+ 'use client';
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.AdminAnalyticsLayout = AdminAnalyticsLayout;
5
+ const jsx_runtime_1 = require("react/jsx-runtime");
6
+ function AdminAnalyticsLayout({ title, timeRange, onTimeRangeChange, children, }) {
7
+ const timeRanges = ['1h', '24h', '7d', '30d'];
8
+ return ((0, jsx_runtime_1.jsxs)("div", { className: "p-6", children: [(0, jsx_runtime_1.jsxs)("div", { className: "flex justify-between items-center mb-6", children: [(0, jsx_runtime_1.jsx)("h1", { className: "text-2xl font-bold", children: title }), (0, jsx_runtime_1.jsx)("div", { className: "flex gap-2", children: timeRanges.map(range => ((0, jsx_runtime_1.jsx)("button", { onClick: () => onTimeRangeChange(range), className: `px-3 py-1 rounded text-sm font-medium transition-colors ${timeRange === range
9
+ ? 'bg-blue-600 text-white'
10
+ : 'bg-gray-200 text-gray-700 hover:bg-gray-300'}`, children: range }, range))) })] }), (0, jsx_runtime_1.jsx)("div", { children: children })] }));
11
+ }
@@ -0,0 +1,7 @@
1
+ import { AuditLogQuery } from '../types';
2
+ interface AuditLogViewerProps {
3
+ query?: Partial<AuditLogQuery>;
4
+ className?: string;
5
+ }
6
+ export declare function AuditLogViewer({ query, className }: AuditLogViewerProps): import("react/jsx-runtime").JSX.Element;
7
+ export {};
@@ -0,0 +1,51 @@
1
+ "use strict";
2
+ 'use client';
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.AuditLogViewer = AuditLogViewer;
5
+ const jsx_runtime_1 = require("react/jsx-runtime");
6
+ const react_1 = require("react");
7
+ const audit_log_1 = require("../api/audit-log");
8
+ function AuditLogViewer({ query = {}, className }) {
9
+ const [logs, setLogs] = (0, react_1.useState)([]);
10
+ const [loading, setLoading] = (0, react_1.useState)(true);
11
+ const [error, setError] = (0, react_1.useState)(null);
12
+ const [page, setPage] = (0, react_1.useState)(1);
13
+ const [totalPages, setTotalPages] = (0, react_1.useState)(1);
14
+ (0, react_1.useEffect)(() => {
15
+ let mounted = true;
16
+ async function fetchLogs() {
17
+ try {
18
+ setLoading(true);
19
+ const result = await (0, audit_log_1.queryAuditLog)({
20
+ ...query,
21
+ page,
22
+ pageSize: 20,
23
+ });
24
+ if (mounted) {
25
+ setLogs(result.data);
26
+ setTotalPages(result.pagination?.totalPages || 1);
27
+ setError(null);
28
+ }
29
+ }
30
+ catch (err) {
31
+ if (mounted) {
32
+ setError(err instanceof Error ? err.message : 'Failed to fetch audit logs');
33
+ }
34
+ }
35
+ finally {
36
+ if (mounted) {
37
+ setLoading(false);
38
+ }
39
+ }
40
+ }
41
+ fetchLogs();
42
+ return () => {
43
+ mounted = false;
44
+ };
45
+ }, [query, page]);
46
+ if (loading)
47
+ return (0, jsx_runtime_1.jsx)("div", { className: className, children: "Loading audit logs..." });
48
+ if (error)
49
+ return (0, jsx_runtime_1.jsxs)("div", { className: className, children: ["Error: ", error] });
50
+ return ((0, jsx_runtime_1.jsxs)("div", { className: className, children: [(0, jsx_runtime_1.jsx)("h3", { className: "text-lg font-semibold mb-4", children: "Audit Log" }), (0, jsx_runtime_1.jsx)("div", { className: "overflow-x-auto", children: (0, jsx_runtime_1.jsxs)("table", { className: "min-w-full divide-y divide-gray-200", children: [(0, jsx_runtime_1.jsx)("thead", { className: "bg-gray-50", children: (0, jsx_runtime_1.jsxs)("tr", { children: [(0, jsx_runtime_1.jsx)("th", { className: "px-4 py-2 text-left text-xs font-medium text-gray-500 uppercase", children: "Timestamp" }), (0, jsx_runtime_1.jsx)("th", { className: "px-4 py-2 text-left text-xs font-medium text-gray-500 uppercase", children: "Category" }), (0, jsx_runtime_1.jsx)("th", { className: "px-4 py-2 text-left text-xs font-medium text-gray-500 uppercase", children: "Action" }), (0, jsx_runtime_1.jsx)("th", { className: "px-4 py-2 text-left text-xs font-medium text-gray-500 uppercase", children: "User ID" }), (0, jsx_runtime_1.jsx)("th", { className: "px-4 py-2 text-left text-xs font-medium text-gray-500 uppercase", children: "Details" })] }) }), (0, jsx_runtime_1.jsx)("tbody", { className: "bg-white divide-y divide-gray-200", children: logs.map(log => ((0, jsx_runtime_1.jsxs)("tr", { className: "hover:bg-gray-50", children: [(0, jsx_runtime_1.jsx)("td", { className: "px-4 py-2 text-sm text-gray-900 font-mono", children: log.timestamp ? new Date(log.timestamp).toLocaleString() : '-' }), (0, jsx_runtime_1.jsx)("td", { className: "px-4 py-2 text-sm text-gray-900", children: log.category }), (0, jsx_runtime_1.jsx)("td", { className: "px-4 py-2 text-sm text-gray-900 font-mono", children: log.action }), (0, jsx_runtime_1.jsx)("td", { className: "px-4 py-2 text-sm text-gray-900", children: log.userId || '-' }), (0, jsx_runtime_1.jsx)("td", { className: "px-4 py-2 text-sm text-gray-500", children: log.details ? JSON.stringify(log.details).slice(0, 50) : '-' })] }, log.id))) })] }) }), totalPages > 1 && ((0, jsx_runtime_1.jsxs)("div", { className: "flex justify-center gap-2 mt-4", children: [(0, jsx_runtime_1.jsx)("button", { onClick: () => setPage(p => Math.max(1, p - 1)), disabled: page === 1, className: "px-3 py-1 rounded bg-gray-200 text-gray-700 disabled:opacity-50", children: "Previous" }), (0, jsx_runtime_1.jsxs)("span", { className: "px-3 py-1", children: ["Page ", page, " of ", totalPages] }), (0, jsx_runtime_1.jsx)("button", { onClick: () => setPage(p => Math.min(totalPages, p + 1)), disabled: page === totalPages, className: "px-3 py-1 rounded bg-gray-200 text-gray-700 disabled:opacity-50", children: "Next" })] }))] }));
51
+ }
@@ -0,0 +1,7 @@
1
+ import { TimeRange } from '../types';
2
+ interface ErrorMetricsCardProps {
3
+ timeRange?: TimeRange;
4
+ className?: string;
5
+ }
6
+ export declare function ErrorMetricsCard({ timeRange, className }: ErrorMetricsCardProps): import("react/jsx-runtime").JSX.Element | null;
7
+ export {};
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+ 'use client';
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.ErrorMetricsCard = ErrorMetricsCard;
5
+ const jsx_runtime_1 = require("react/jsx-runtime");
6
+ const useErrorMetrics_1 = require("../hooks/useErrorMetrics");
7
+ function ErrorMetricsCard({ timeRange = '24h', className }) {
8
+ const { data, loading, error } = (0, useErrorMetrics_1.useErrorMetrics)(timeRange);
9
+ if (loading)
10
+ return (0, jsx_runtime_1.jsx)("div", { className: className, children: "Loading error metrics..." });
11
+ if (error)
12
+ return (0, jsx_runtime_1.jsxs)("div", { className: className, children: ["Error: ", error] });
13
+ if (!data)
14
+ return null;
15
+ return ((0, jsx_runtime_1.jsxs)("div", { className: className, children: [(0, jsx_runtime_1.jsxs)("h3", { className: "text-lg font-semibold mb-4", children: ["Error Metrics", (0, jsx_runtime_1.jsxs)("span", { className: "text-sm text-gray-500 ml-2", children: ["(", new Date(data.periodStart).toLocaleDateString(), " - ", new Date(data.periodEnd).toLocaleDateString(), ")"] })] }), (0, jsx_runtime_1.jsxs)("div", { className: "mb-4", children: [(0, jsx_runtime_1.jsx)("span", { className: "text-3xl font-bold", children: data.totalErrors }), (0, jsx_runtime_1.jsx)("span", { className: "text-gray-600 ml-2", children: "total errors" })] }), data.topFailingRoutes && data.topFailingRoutes.length > 0 && ((0, jsx_runtime_1.jsxs)("div", { className: "mb-4", children: [(0, jsx_runtime_1.jsx)("h4", { className: "font-medium mb-2", children: "Top Failing Routes" }), (0, jsx_runtime_1.jsx)("ul", { className: "space-y-1", children: data.topFailingRoutes.slice(0, 5).map((route, idx) => ((0, jsx_runtime_1.jsxs)("li", { className: "flex justify-between text-sm", children: [(0, jsx_runtime_1.jsx)("span", { className: "font-mono", children: route.route }), (0, jsx_runtime_1.jsxs)("span", { className: "text-red-600", children: [route.count, " errors"] })] }, idx))) })] })), (0, jsx_runtime_1.jsxs)("div", { className: "mb-4", children: [(0, jsx_runtime_1.jsx)("h4", { className: "font-medium mb-2", children: "By Severity" }), (0, jsx_runtime_1.jsxs)("div", { className: "flex gap-4", children: [(0, jsx_runtime_1.jsxs)("div", { className: "text-sm", children: [(0, jsx_runtime_1.jsx)("span", { className: "font-medium", children: "Error:" }), (0, jsx_runtime_1.jsx)("span", { className: "ml-1", children: data.errorCount })] }), (0, jsx_runtime_1.jsxs)("div", { className: "text-sm", children: [(0, jsx_runtime_1.jsx)("span", { className: "font-medium", children: "Warn:" }), (0, jsx_runtime_1.jsx)("span", { className: "ml-1", children: data.warnCount })] }), (0, jsx_runtime_1.jsxs)("div", { className: "text-sm", children: [(0, jsx_runtime_1.jsx)("span", { className: "font-medium", children: "Fatal:" }), (0, jsx_runtime_1.jsx)("span", { className: "ml-1", children: data.fatalCount })] })] })] }), data.byCategory && data.byCategory.length > 0 && ((0, jsx_runtime_1.jsxs)("div", { className: "mb-4", children: [(0, jsx_runtime_1.jsx)("h4", { className: "font-medium mb-2", children: "By Category" }), (0, jsx_runtime_1.jsx)("div", { className: "flex flex-wrap gap-2", children: data.byCategory.map((cat, idx) => ((0, jsx_runtime_1.jsxs)("div", { className: "text-sm bg-gray-100 px-2 py-1 rounded", children: [(0, jsx_runtime_1.jsxs)("span", { className: "font-medium", children: [cat.category, ":"] }), (0, jsx_runtime_1.jsx)("span", { className: "ml-1", children: cat.count })] }, idx))) })] })), data.topErrorCodes && data.topErrorCodes.length > 0 && ((0, jsx_runtime_1.jsxs)("div", { children: [(0, jsx_runtime_1.jsx)("h4", { className: "font-medium mb-2", children: "Top Error Codes" }), (0, jsx_runtime_1.jsx)("ul", { className: "space-y-1", children: data.topErrorCodes.slice(0, 5).map((code, idx) => ((0, jsx_runtime_1.jsxs)("li", { className: "flex justify-between text-sm", children: [(0, jsx_runtime_1.jsx)("span", { className: "font-mono", children: code.errorCode }), (0, jsx_runtime_1.jsx)("span", { className: "text-orange-600", children: code.count })] }, idx))) })] }))] }));
16
+ }
@@ -0,0 +1,7 @@
1
+ import { TimeRange } from '../types';
2
+ interface HealthMetricsCardProps {
3
+ timeRange?: TimeRange;
4
+ className?: string;
5
+ }
6
+ export declare function HealthMetricsCard({ timeRange, className }: HealthMetricsCardProps): import("react/jsx-runtime").JSX.Element | null;
7
+ export {};
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ 'use client';
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.HealthMetricsCard = HealthMetricsCard;
5
+ const jsx_runtime_1 = require("react/jsx-runtime");
6
+ const useHealthMetrics_1 = require("../hooks/useHealthMetrics");
7
+ function HealthMetricsCard({ timeRange = '1h', className }) {
8
+ const { data, loading, error } = (0, useHealthMetrics_1.useHealthMetrics)(timeRange);
9
+ if (loading)
10
+ return (0, jsx_runtime_1.jsx)("div", { className: className, children: "Loading health metrics..." });
11
+ if (error)
12
+ return (0, jsx_runtime_1.jsxs)("div", { className: className, children: ["Error: ", error] });
13
+ if (!data)
14
+ return null;
15
+ return ((0, jsx_runtime_1.jsxs)("div", { className: className, children: [(0, jsx_runtime_1.jsxs)("h3", { className: "text-lg font-semibold mb-4", children: ["System Health (", data.timeRange, ")"] }), (0, jsx_runtime_1.jsxs)("div", { className: "grid grid-cols-2 gap-4 mb-4", children: [(0, jsx_runtime_1.jsxs)("div", { children: [(0, jsx_runtime_1.jsxs)("div", { className: "text-2xl font-bold", children: [data.apiHealth.avgResponseTimeMs, "ms"] }), (0, jsx_runtime_1.jsx)("div", { className: "text-sm text-gray-600", children: "Avg Response Time" })] }), (0, jsx_runtime_1.jsxs)("div", { children: [(0, jsx_runtime_1.jsx)("div", { className: "text-2xl font-bold", children: data.apiHealth.requestCount }), (0, jsx_runtime_1.jsx)("div", { className: "text-sm text-gray-600", children: "Total Requests" })] }), (0, jsx_runtime_1.jsxs)("div", { children: [(0, jsx_runtime_1.jsxs)("div", { className: "text-2xl font-bold", children: [data.apiHealth.p95ResponseTimeMs, "ms"] }), (0, jsx_runtime_1.jsx)("div", { className: "text-sm text-gray-600", children: "P95 Response Time" })] }), (0, jsx_runtime_1.jsxs)("div", { children: [(0, jsx_runtime_1.jsxs)("div", { className: "text-2xl font-bold", children: [(data.apiHealth.errorRate * 100).toFixed(2), "%"] }), (0, jsx_runtime_1.jsx)("div", { className: "text-sm text-gray-600", children: "Error Rate" })] })] }), data.endpointBreakdown.length > 0 && ((0, jsx_runtime_1.jsxs)("div", { className: "mb-4", children: [(0, jsx_runtime_1.jsx)("h4", { className: "font-medium mb-2", children: "Slowest Endpoints" }), (0, jsx_runtime_1.jsx)("ul", { className: "space-y-1", children: data.endpointBreakdown
16
+ .sort((a, b) => b.avgDurationMs - a.avgDurationMs)
17
+ .slice(0, 5)
18
+ .map((ep, i) => ((0, jsx_runtime_1.jsxs)("li", { className: "flex justify-between text-sm", children: [(0, jsx_runtime_1.jsx)("span", { className: "font-mono", children: ep.endpoint }), (0, jsx_runtime_1.jsxs)("span", { className: "text-orange-600", children: [ep.avgDurationMs, "ms"] })] }, i))) })] })), data.rateLimitHits > 0 && ((0, jsx_runtime_1.jsxs)("div", { className: "text-sm text-yellow-600", children: ["\u26A0\uFE0F ", data.rateLimitHits, " rate limit hits"] }))] }));
19
+ }
@@ -0,0 +1,24 @@
1
+ import { TimeRange } from '../types';
2
+ /**
3
+ * Combined hook for admin analytics
4
+ * Fetches both error and health metrics
5
+ */
6
+ export declare function useAdminAnalytics(timeRange?: TimeRange): {
7
+ errorMetrics: {
8
+ data: import("../types").ErrorMetrics | null;
9
+ loading: boolean;
10
+ error: string | null;
11
+ };
12
+ healthMetrics: {
13
+ data: import("../types").HealthMetrics | null;
14
+ loading: boolean;
15
+ error: string | null;
16
+ };
17
+ auditLog: {
18
+ log: (entry: Omit<import("../types").AuditLogEntry, "id" | "timestamp">) => Promise<void>;
19
+ writing: boolean;
20
+ error: string | null;
21
+ };
22
+ loading: boolean;
23
+ error: string | null;
24
+ };
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.useAdminAnalytics = useAdminAnalytics;
4
+ const useErrorMetrics_1 = require("./useErrorMetrics");
5
+ const useHealthMetrics_1 = require("./useHealthMetrics");
6
+ const useAuditLog_1 = require("./useAuditLog");
7
+ /**
8
+ * Combined hook for admin analytics
9
+ * Fetches both error and health metrics
10
+ */
11
+ function useAdminAnalytics(timeRange = '24h') {
12
+ const errorMetrics = (0, useErrorMetrics_1.useErrorMetrics)(timeRange);
13
+ const healthMetrics = (0, useHealthMetrics_1.useHealthMetrics)(timeRange);
14
+ const auditLog = (0, useAuditLog_1.useAuditLog)();
15
+ return {
16
+ errorMetrics,
17
+ healthMetrics,
18
+ auditLog,
19
+ loading: errorMetrics.loading || healthMetrics.loading,
20
+ error: errorMetrics.error || healthMetrics.error,
21
+ };
22
+ }
@@ -0,0 +1,6 @@
1
+ import { AuditLogEntry } from '../types';
2
+ export declare function useAuditLog(): {
3
+ log: (entry: Omit<AuditLogEntry, "id" | "timestamp">) => Promise<void>;
4
+ writing: boolean;
5
+ error: string | null;
6
+ };
@@ -0,0 +1,25 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.useAuditLog = useAuditLog;
4
+ const react_1 = require("react");
5
+ const audit_log_1 = require("../api/audit-log");
6
+ function useAuditLog() {
7
+ const [writing, setWriting] = (0, react_1.useState)(false);
8
+ const [error, setError] = (0, react_1.useState)(null);
9
+ async function log(entry) {
10
+ try {
11
+ setWriting(true);
12
+ setError(null);
13
+ await (0, audit_log_1.writeAuditLog)(entry);
14
+ }
15
+ catch (err) {
16
+ const errMessage = err instanceof Error ? err.message : 'Failed to write audit log';
17
+ setError(errMessage);
18
+ throw err;
19
+ }
20
+ finally {
21
+ setWriting(false);
22
+ }
23
+ }
24
+ return { log, writing, error };
25
+ }
@@ -0,0 +1,6 @@
1
+ import { ErrorMetrics, TimeRange } from '../types';
2
+ export declare function useErrorMetrics(timeRange?: TimeRange): {
3
+ data: ErrorMetrics | null;
4
+ loading: boolean;
5
+ error: string | null;
6
+ };
@@ -0,0 +1,38 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.useErrorMetrics = useErrorMetrics;
4
+ const react_1 = require("react");
5
+ const admin_analytics_1 = require("../api/admin-analytics");
6
+ function useErrorMetrics(timeRange = '24h') {
7
+ const [data, setData] = (0, react_1.useState)(null);
8
+ const [loading, setLoading] = (0, react_1.useState)(true);
9
+ const [error, setError] = (0, react_1.useState)(null);
10
+ (0, react_1.useEffect)(() => {
11
+ let mounted = true;
12
+ async function fetchData() {
13
+ try {
14
+ setLoading(true);
15
+ const result = await (0, admin_analytics_1.getErrorMetrics)(timeRange);
16
+ if (mounted) {
17
+ setData(result.data);
18
+ setError(null);
19
+ }
20
+ }
21
+ catch (err) {
22
+ if (mounted) {
23
+ setError(err instanceof Error ? err.message : 'Failed to fetch error metrics');
24
+ }
25
+ }
26
+ finally {
27
+ if (mounted) {
28
+ setLoading(false);
29
+ }
30
+ }
31
+ }
32
+ fetchData();
33
+ return () => {
34
+ mounted = false;
35
+ };
36
+ }, [timeRange]);
37
+ return { data, loading, error };
38
+ }