@payez/next-mvp 4.0.0 → 4.0.1

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 (459) hide show
  1. package/package.json +6 -16
  2. package/dist/api/auth-handler.d.ts +0 -66
  3. package/dist/api/auth-handler.js +0 -397
  4. package/dist/api/index.d.ts +0 -10
  5. package/dist/api/index.js +0 -19
  6. package/dist/api-handlers/account/change-password.d.ts +0 -9
  7. package/dist/api-handlers/account/change-password.js +0 -110
  8. package/dist/api-handlers/account/masked-info.d.ts +0 -2
  9. package/dist/api-handlers/account/masked-info.js +0 -41
  10. package/dist/api-handlers/account/profile.d.ts +0 -3
  11. package/dist/api-handlers/account/profile.js +0 -63
  12. package/dist/api-handlers/account/recovery/initiate.d.ts +0 -2
  13. package/dist/api-handlers/account/recovery/initiate.js +0 -26
  14. package/dist/api-handlers/account/recovery/send-code.d.ts +0 -2
  15. package/dist/api-handlers/account/recovery/send-code.js +0 -28
  16. package/dist/api-handlers/account/recovery/verify-code.d.ts +0 -2
  17. package/dist/api-handlers/account/recovery/verify-code.js +0 -28
  18. package/dist/api-handlers/account/reset-password.d.ts +0 -2
  19. package/dist/api-handlers/account/reset-password.js +0 -26
  20. package/dist/api-handlers/account/send-code.d.ts +0 -24
  21. package/dist/api-handlers/account/send-code.js +0 -60
  22. package/dist/api-handlers/account/update-phone.d.ts +0 -27
  23. package/dist/api-handlers/account/update-phone.js +0 -64
  24. package/dist/api-handlers/account/validate-password.d.ts +0 -17
  25. package/dist/api-handlers/account/validate-password.js +0 -81
  26. package/dist/api-handlers/account/verify-email.d.ts +0 -26
  27. package/dist/api-handlers/account/verify-email.js +0 -106
  28. package/dist/api-handlers/account/verify-sms.d.ts +0 -26
  29. package/dist/api-handlers/account/verify-sms.js +0 -106
  30. package/dist/api-handlers/admin/analytics.d.ts +0 -19
  31. package/dist/api-handlers/admin/analytics.js +0 -378
  32. package/dist/api-handlers/admin/audit.d.ts +0 -19
  33. package/dist/api-handlers/admin/audit.js +0 -213
  34. package/dist/api-handlers/admin/index.d.ts +0 -21
  35. package/dist/api-handlers/admin/index.js +0 -42
  36. package/dist/api-handlers/admin/redis-sessions.d.ts +0 -35
  37. package/dist/api-handlers/admin/redis-sessions.js +0 -203
  38. package/dist/api-handlers/admin/sessions.d.ts +0 -20
  39. package/dist/api-handlers/admin/sessions.js +0 -283
  40. package/dist/api-handlers/admin/site-logs.d.ts +0 -45
  41. package/dist/api-handlers/admin/site-logs.js +0 -317
  42. package/dist/api-handlers/admin/stats.d.ts +0 -20
  43. package/dist/api-handlers/admin/stats.js +0 -239
  44. package/dist/api-handlers/admin/users.d.ts +0 -19
  45. package/dist/api-handlers/admin/users.js +0 -221
  46. package/dist/api-handlers/admin/vibe-data.d.ts +0 -79
  47. package/dist/api-handlers/admin/vibe-data.js +0 -267
  48. package/dist/api-handlers/anon/preferences.d.ts +0 -37
  49. package/dist/api-handlers/anon/preferences.js +0 -96
  50. package/dist/api-handlers/auth/jwks.d.ts +0 -2
  51. package/dist/api-handlers/auth/jwks.js +0 -24
  52. package/dist/api-handlers/auth/login.d.ts +0 -42
  53. package/dist/api-handlers/auth/login.js +0 -178
  54. package/dist/api-handlers/auth/refresh.d.ts +0 -74
  55. package/dist/api-handlers/auth/refresh.js +0 -633
  56. package/dist/api-handlers/auth/signout.d.ts +0 -37
  57. package/dist/api-handlers/auth/signout.js +0 -186
  58. package/dist/api-handlers/auth/status.d.ts +0 -8
  59. package/dist/api-handlers/auth/status.js +0 -23
  60. package/dist/api-handlers/auth/update-session.d.ts +0 -37
  61. package/dist/api-handlers/auth/update-session.js +0 -93
  62. package/dist/api-handlers/auth/validate.d.ts +0 -6
  63. package/dist/api-handlers/auth/validate.js +0 -43
  64. package/dist/api-handlers/auth/verify-code.d.ts +0 -43
  65. package/dist/api-handlers/auth/verify-code.js +0 -90
  66. package/dist/api-handlers/session/refresh-viability.d.ts +0 -14
  67. package/dist/api-handlers/session/refresh-viability.js +0 -39
  68. package/dist/api-handlers/session/viability.d.ts +0 -13
  69. package/dist/api-handlers/session/viability.js +0 -114
  70. package/dist/api-handlers/test/force-expire.d.ts +0 -23
  71. package/dist/api-handlers/test/force-expire.js +0 -59
  72. package/dist/auth/auth-decision.d.ts +0 -39
  73. package/dist/auth/auth-decision.js +0 -182
  74. package/dist/auth/auth-options.d.ts +0 -57
  75. package/dist/auth/auth-options.js +0 -213
  76. package/dist/auth/better-auth.d.ts +0 -79
  77. package/dist/auth/better-auth.js +0 -119
  78. package/dist/auth/callbacks/index.d.ts +0 -6
  79. package/dist/auth/callbacks/index.js +0 -12
  80. package/dist/auth/callbacks/jwt.d.ts +0 -45
  81. package/dist/auth/callbacks/jwt.js +0 -305
  82. package/dist/auth/callbacks/session.d.ts +0 -60
  83. package/dist/auth/callbacks/session.js +0 -170
  84. package/dist/auth/callbacks/signin.d.ts +0 -23
  85. package/dist/auth/callbacks/signin.js +0 -44
  86. package/dist/auth/events/index.d.ts +0 -4
  87. package/dist/auth/events/index.js +0 -8
  88. package/dist/auth/events/signout.d.ts +0 -17
  89. package/dist/auth/events/signout.js +0 -32
  90. package/dist/auth/providers/credentials.d.ts +0 -32
  91. package/dist/auth/providers/credentials.js +0 -223
  92. package/dist/auth/providers/index.d.ts +0 -5
  93. package/dist/auth/providers/index.js +0 -21
  94. package/dist/auth/providers/oauth.d.ts +0 -26
  95. package/dist/auth/providers/oauth.js +0 -105
  96. package/dist/auth/route-config.d.ts +0 -66
  97. package/dist/auth/route-config.js +0 -190
  98. package/dist/auth/types/auth-types.d.ts +0 -417
  99. package/dist/auth/types/auth-types.js +0 -53
  100. package/dist/auth/types/index.d.ts +0 -6
  101. package/dist/auth/types/index.js +0 -22
  102. package/dist/auth/unauthenticated-routes.d.ts +0 -1
  103. package/dist/auth/unauthenticated-routes.js +0 -19
  104. package/dist/auth/utils/idp-client.d.ts +0 -94
  105. package/dist/auth/utils/idp-client.js +0 -384
  106. package/dist/auth/utils/index.d.ts +0 -5
  107. package/dist/auth/utils/index.js +0 -21
  108. package/dist/auth/utils/token-utils.d.ts +0 -83
  109. package/dist/auth/utils/token-utils.js +0 -218
  110. package/dist/client/AuthContext.d.ts +0 -19
  111. package/dist/client/AuthContext.js +0 -115
  112. package/dist/client/better-auth-client.d.ts +0 -1020
  113. package/dist/client/better-auth-client.js +0 -68
  114. package/dist/client/fetch-with-auth.d.ts +0 -11
  115. package/dist/client/fetch-with-auth.js +0 -44
  116. package/dist/client/fetchWithSession.d.ts +0 -3
  117. package/dist/client/fetchWithSession.js +0 -24
  118. package/dist/client/index.d.ts +0 -9
  119. package/dist/client/index.js +0 -20
  120. package/dist/client/useAnonSession.d.ts +0 -36
  121. package/dist/client/useAnonSession.js +0 -99
  122. package/dist/components/SessionSync.d.ts +0 -13
  123. package/dist/components/SessionSync.js +0 -121
  124. package/dist/components/SignalRHealthCheck.d.ts +0 -10
  125. package/dist/components/SignalRHealthCheck.js +0 -97
  126. package/dist/components/account/MobileNavDrawer.d.ts +0 -32
  127. package/dist/components/account/MobileNavDrawer.js +0 -81
  128. package/dist/components/account/UserAvatarMenu.d.ts +0 -20
  129. package/dist/components/account/UserAvatarMenu.js +0 -91
  130. package/dist/components/account/index.d.ts +0 -9
  131. package/dist/components/account/index.js +0 -13
  132. package/dist/components/admin/AlertSettingsTab.d.ts +0 -48
  133. package/dist/components/admin/AlertSettingsTab.js +0 -351
  134. package/dist/components/admin/AnalyticsTab.d.ts +0 -22
  135. package/dist/components/admin/AnalyticsTab.js +0 -167
  136. package/dist/components/admin/DataBrowserTab.d.ts +0 -19
  137. package/dist/components/admin/DataBrowserTab.js +0 -252
  138. package/dist/components/admin/LoggingSettingsTab.d.ts +0 -73
  139. package/dist/components/admin/LoggingSettingsTab.js +0 -339
  140. package/dist/components/admin/SessionsTab.d.ts +0 -37
  141. package/dist/components/admin/SessionsTab.js +0 -165
  142. package/dist/components/admin/StatsTab.d.ts +0 -53
  143. package/dist/components/admin/StatsTab.js +0 -161
  144. package/dist/components/admin/VibeAdminContext.d.ts +0 -32
  145. package/dist/components/admin/VibeAdminContext.js +0 -38
  146. package/dist/components/admin/VibeAdminLayout.d.ts +0 -11
  147. package/dist/components/admin/VibeAdminLayout.js +0 -71
  148. package/dist/components/admin/index.d.ts +0 -29
  149. package/dist/components/admin/index.js +0 -44
  150. package/dist/components/auth/FederatedAuthSection.d.ts +0 -8
  151. package/dist/components/auth/FederatedAuthSection.js +0 -45
  152. package/dist/components/auth/ModeAwareLoginPage.d.ts +0 -10
  153. package/dist/components/auth/ModeAwareLoginPage.js +0 -42
  154. package/dist/components/auth/ModeAwareSignupPage.d.ts +0 -9
  155. package/dist/components/auth/ModeAwareSignupPage.js +0 -78
  156. package/dist/components/auth/TraditionalAuthSection.d.ts +0 -14
  157. package/dist/components/auth/TraditionalAuthSection.js +0 -20
  158. package/dist/components/recovery/CompleteStep.d.ts +0 -5
  159. package/dist/components/recovery/CompleteStep.js +0 -8
  160. package/dist/components/recovery/InitiateRecoveryStep.d.ts +0 -8
  161. package/dist/components/recovery/InitiateRecoveryStep.js +0 -20
  162. package/dist/components/recovery/SelectMethodStep.d.ts +0 -8
  163. package/dist/components/recovery/SelectMethodStep.js +0 -8
  164. package/dist/components/recovery/SetPasswordStep.d.ts +0 -6
  165. package/dist/components/recovery/SetPasswordStep.js +0 -20
  166. package/dist/components/recovery/VerifyCodeStep.d.ts +0 -10
  167. package/dist/components/recovery/VerifyCodeStep.js +0 -24
  168. package/dist/components/reserved/ReservedRecoveryWarning.d.ts +0 -38
  169. package/dist/components/reserved/ReservedRecoveryWarning.js +0 -92
  170. package/dist/components/reserved/ReservedStatusBox.d.ts +0 -30
  171. package/dist/components/reserved/ReservedStatusBox.js +0 -71
  172. package/dist/components/ui/BetaBadge.d.ts +0 -29
  173. package/dist/components/ui/BetaBadge.js +0 -38
  174. package/dist/components/ui/Footer.d.ts +0 -37
  175. package/dist/components/ui/Footer.js +0 -41
  176. package/dist/config/env.d.ts +0 -66
  177. package/dist/config/env.js +0 -57
  178. package/dist/config/logger.d.ts +0 -57
  179. package/dist/config/logger.js +0 -73
  180. package/dist/config/logging-config.d.ts +0 -30
  181. package/dist/config/logging-config.js +0 -122
  182. package/dist/config/unauthenticated-routes.d.ts +0 -17
  183. package/dist/config/unauthenticated-routes.js +0 -24
  184. package/dist/config/vibe-log-transport.d.ts +0 -81
  185. package/dist/config/vibe-log-transport.js +0 -212
  186. package/dist/edge/internal-api-url.d.ts +0 -53
  187. package/dist/edge/internal-api-url.js +0 -63
  188. package/dist/edge/middleware.d.ts +0 -14
  189. package/dist/edge/middleware.js +0 -32
  190. package/dist/hooks/useAuth.d.ts +0 -23
  191. package/dist/hooks/useAuth.js +0 -83
  192. package/dist/hooks/useAuthSettings.d.ts +0 -59
  193. package/dist/hooks/useAuthSettings.js +0 -93
  194. package/dist/hooks/useAvailableProviders.d.ts +0 -43
  195. package/dist/hooks/useAvailableProviders.js +0 -112
  196. package/dist/hooks/usePasswordValidation.d.ts +0 -27
  197. package/dist/hooks/usePasswordValidation.js +0 -102
  198. package/dist/hooks/useProfile.d.ts +0 -15
  199. package/dist/hooks/useProfile.js +0 -59
  200. package/dist/hooks/usePublicAuthSettings.d.ts +0 -56
  201. package/dist/hooks/usePublicAuthSettings.js +0 -131
  202. package/dist/hooks/useSessionExpiration.d.ts +0 -56
  203. package/dist/hooks/useSessionExpiration.js +0 -72
  204. package/dist/hooks/useViabilitySession.d.ts +0 -75
  205. package/dist/hooks/useViabilitySession.js +0 -269
  206. package/dist/index.d.ts +0 -12
  207. package/dist/index.js +0 -53
  208. package/dist/lib/anon-session.d.ts +0 -74
  209. package/dist/lib/anon-session.js +0 -169
  210. package/dist/lib/api-handler.d.ts +0 -123
  211. package/dist/lib/api-handler.js +0 -478
  212. package/dist/lib/app-slug.d.ts +0 -95
  213. package/dist/lib/app-slug.js +0 -172
  214. package/dist/lib/demo-mode.d.ts +0 -6
  215. package/dist/lib/demo-mode.js +0 -16
  216. package/dist/lib/geolocation.d.ts +0 -64
  217. package/dist/lib/geolocation.js +0 -235
  218. package/dist/lib/idp-client-config.d.ts +0 -75
  219. package/dist/lib/idp-client-config.js +0 -425
  220. package/dist/lib/idp-fetch.d.ts +0 -14
  221. package/dist/lib/idp-fetch.js +0 -91
  222. package/dist/lib/internal-api.d.ts +0 -87
  223. package/dist/lib/internal-api.js +0 -122
  224. package/dist/lib/jwt-decode-client.d.ts +0 -10
  225. package/dist/lib/jwt-decode-client.js +0 -46
  226. package/dist/lib/jwt-decode.d.ts +0 -48
  227. package/dist/lib/jwt-decode.js +0 -57
  228. package/dist/lib/nextauth-secret.d.ts +0 -10
  229. package/dist/lib/nextauth-secret.js +0 -100
  230. package/dist/lib/rate-limit-service.d.ts +0 -23
  231. package/dist/lib/rate-limit-service.js +0 -6
  232. package/dist/lib/redis.d.ts +0 -5
  233. package/dist/lib/redis.js +0 -28
  234. package/dist/lib/refresh-token-validator.d.ts +0 -13
  235. package/dist/lib/refresh-token-validator.js +0 -117
  236. package/dist/lib/roles.d.ts +0 -145
  237. package/dist/lib/roles.js +0 -168
  238. package/dist/lib/secret-validation.d.ts +0 -4
  239. package/dist/lib/secret-validation.js +0 -14
  240. package/dist/lib/session-store.d.ts +0 -170
  241. package/dist/lib/session-store.js +0 -545
  242. package/dist/lib/session.d.ts +0 -21
  243. package/dist/lib/session.js +0 -26
  244. package/dist/lib/site-logger.d.ts +0 -214
  245. package/dist/lib/site-logger.js +0 -210
  246. package/dist/lib/standardized-client-api.d.ts +0 -161
  247. package/dist/lib/standardized-client-api.js +0 -791
  248. package/dist/lib/startup-init.d.ts +0 -40
  249. package/dist/lib/startup-init.js +0 -257
  250. package/dist/lib/test-aware-get-token.d.ts +0 -2
  251. package/dist/lib/test-aware-get-token.js +0 -86
  252. package/dist/lib/token-expiry.d.ts +0 -14
  253. package/dist/lib/token-expiry.js +0 -39
  254. package/dist/lib/token-lifecycle.d.ts +0 -78
  255. package/dist/lib/token-lifecycle.js +0 -360
  256. package/dist/lib/types/api-responses.d.ts +0 -128
  257. package/dist/lib/types/api-responses.js +0 -171
  258. package/dist/lib/user-agent-parser.d.ts +0 -50
  259. package/dist/lib/user-agent-parser.js +0 -220
  260. package/dist/logging/api/admin-analytics.d.ts +0 -3
  261. package/dist/logging/api/admin-analytics.js +0 -45
  262. package/dist/logging/api/audit-log.d.ts +0 -3
  263. package/dist/logging/api/audit-log.js +0 -52
  264. package/dist/logging/components/AdminAnalyticsLayout.d.ts +0 -10
  265. package/dist/logging/components/AdminAnalyticsLayout.js +0 -11
  266. package/dist/logging/components/AuditLogViewer.d.ts +0 -7
  267. package/dist/logging/components/AuditLogViewer.js +0 -51
  268. package/dist/logging/components/ErrorMetricsCard.d.ts +0 -7
  269. package/dist/logging/components/ErrorMetricsCard.js +0 -16
  270. package/dist/logging/components/HealthMetricsCard.d.ts +0 -7
  271. package/dist/logging/components/HealthMetricsCard.js +0 -19
  272. package/dist/logging/hooks/useAdminAnalytics.d.ts +0 -24
  273. package/dist/logging/hooks/useAdminAnalytics.js +0 -22
  274. package/dist/logging/hooks/useAuditLog.d.ts +0 -6
  275. package/dist/logging/hooks/useAuditLog.js +0 -25
  276. package/dist/logging/hooks/useErrorMetrics.d.ts +0 -6
  277. package/dist/logging/hooks/useErrorMetrics.js +0 -38
  278. package/dist/logging/hooks/useHealthMetrics.d.ts +0 -6
  279. package/dist/logging/hooks/useHealthMetrics.js +0 -41
  280. package/dist/logging/index.d.ts +0 -11
  281. package/dist/logging/index.js +0 -40
  282. package/dist/logging/types/analytics.d.ts +0 -68
  283. package/dist/logging/types/analytics.js +0 -3
  284. package/dist/logging/types/audit.d.ts +0 -29
  285. package/dist/logging/types/audit.js +0 -2
  286. package/dist/logging/types/index.d.ts +0 -2
  287. package/dist/logging/types/index.js +0 -19
  288. package/dist/middleware/auth-decision.d.ts +0 -33
  289. package/dist/middleware/auth-decision.js +0 -65
  290. package/dist/middleware/create-middleware.d.ts +0 -102
  291. package/dist/middleware/create-middleware.js +0 -469
  292. package/dist/middleware/rbac-check.d.ts +0 -51
  293. package/dist/middleware/rbac-check.js +0 -219
  294. package/dist/middleware/twofa-presets.d.ts +0 -134
  295. package/dist/middleware/twofa-presets.js +0 -175
  296. package/dist/models/DecodedAccessToken.d.ts +0 -17
  297. package/dist/models/DecodedAccessToken.js +0 -2
  298. package/dist/models/SessionModel.d.ts +0 -122
  299. package/dist/models/SessionModel.js +0 -136
  300. package/dist/pages/admin-login/page.d.ts +0 -31
  301. package/dist/pages/admin-login/page.js +0 -73
  302. package/dist/pages/admin-page-permissions/PagePermissionsAdminPage.d.ts +0 -18
  303. package/dist/pages/admin-page-permissions/PagePermissionsAdminPage.js +0 -276
  304. package/dist/pages/admin-page-permissions/index.d.ts +0 -6
  305. package/dist/pages/admin-page-permissions/index.js +0 -13
  306. package/dist/pages/admin-roles/RolesAdminPage.d.ts +0 -16
  307. package/dist/pages/admin-roles/RolesAdminPage.js +0 -261
  308. package/dist/pages/admin-roles/index.d.ts +0 -8
  309. package/dist/pages/admin-roles/index.js +0 -15
  310. package/dist/pages/admin-roles/modals.d.ts +0 -72
  311. package/dist/pages/admin-roles/modals.js +0 -154
  312. package/dist/pages/client-admin/ClientSiteAdminPage.d.ts +0 -79
  313. package/dist/pages/client-admin/ClientSiteAdminPage.js +0 -179
  314. package/dist/pages/client-admin/index.d.ts +0 -32
  315. package/dist/pages/client-admin/index.js +0 -37
  316. package/dist/pages/coming-soon/page.d.ts +0 -8
  317. package/dist/pages/coming-soon/page.js +0 -28
  318. package/dist/pages/login/page.d.ts +0 -22
  319. package/dist/pages/login/page.js +0 -230
  320. package/dist/pages/profile/EnhancedProfilePage.d.ts +0 -13
  321. package/dist/pages/profile/EnhancedProfilePage.js +0 -150
  322. package/dist/pages/profile/index.d.ts +0 -8
  323. package/dist/pages/profile/index.js +0 -16
  324. package/dist/pages/profile/page.d.ts +0 -19
  325. package/dist/pages/profile/page.js +0 -47
  326. package/dist/pages/profile/profile-patch.d.ts +0 -1
  327. package/dist/pages/profile/profile-patch.js +0 -281
  328. package/dist/pages/recovery/page.d.ts +0 -1
  329. package/dist/pages/recovery/page.js +0 -142
  330. package/dist/pages/roles/MyRolesPage.d.ts +0 -24
  331. package/dist/pages/roles/MyRolesPage.js +0 -71
  332. package/dist/pages/roles/components.d.ts +0 -63
  333. package/dist/pages/roles/components.js +0 -108
  334. package/dist/pages/roles/index.d.ts +0 -8
  335. package/dist/pages/roles/index.js +0 -19
  336. package/dist/pages/security/EnhancedSecurityPage.d.ts +0 -14
  337. package/dist/pages/security/EnhancedSecurityPage.js +0 -248
  338. package/dist/pages/security/index.d.ts +0 -8
  339. package/dist/pages/security/index.js +0 -16
  340. package/dist/pages/security/page.d.ts +0 -21
  341. package/dist/pages/security/page.js +0 -212
  342. package/dist/pages/security/security-patch.d.ts +0 -1
  343. package/dist/pages/security/security-patch.js +0 -302
  344. package/dist/pages/settings/EnhancedSettingsPage.d.ts +0 -46
  345. package/dist/pages/settings/EnhancedSettingsPage.js +0 -231
  346. package/dist/pages/settings/index.d.ts +0 -8
  347. package/dist/pages/settings/index.js +0 -16
  348. package/dist/pages/settings/page.d.ts +0 -7
  349. package/dist/pages/settings/page.js +0 -26
  350. package/dist/pages/showcase/ShowcasePage.d.ts +0 -13
  351. package/dist/pages/showcase/ShowcasePage.js +0 -142
  352. package/dist/pages/showcase/index.d.ts +0 -12
  353. package/dist/pages/showcase/index.js +0 -17
  354. package/dist/pages/test-env/EmergencyLogoutPage.d.ts +0 -14
  355. package/dist/pages/test-env/EmergencyLogoutPage.js +0 -99
  356. package/dist/pages/test-env/JwtInspectPage.d.ts +0 -14
  357. package/dist/pages/test-env/JwtInspectPage.js +0 -116
  358. package/dist/pages/test-env/RefreshTokenPage.d.ts +0 -15
  359. package/dist/pages/test-env/RefreshTokenPage.js +0 -93
  360. package/dist/pages/test-env/TestEnvPage.d.ts +0 -13
  361. package/dist/pages/test-env/TestEnvPage.js +0 -51
  362. package/dist/pages/test-env/index.d.ts +0 -24
  363. package/dist/pages/test-env/index.js +0 -32
  364. package/dist/pages/verify-code/page.d.ts +0 -30
  365. package/dist/pages/verify-code/page.js +0 -412
  366. package/dist/routes/account/index.d.ts +0 -28
  367. package/dist/routes/account/index.js +0 -71
  368. package/dist/routes/account/masked-info.d.ts +0 -33
  369. package/dist/routes/account/masked-info.js +0 -39
  370. package/dist/routes/account/send-code.d.ts +0 -37
  371. package/dist/routes/account/send-code.js +0 -42
  372. package/dist/routes/account/update-phone.d.ts +0 -13
  373. package/dist/routes/account/update-phone.js +0 -17
  374. package/dist/routes/account/verify-email.d.ts +0 -38
  375. package/dist/routes/account/verify-email.js +0 -43
  376. package/dist/routes/account/verify-sms.d.ts +0 -38
  377. package/dist/routes/account/verify-sms.js +0 -43
  378. package/dist/routes/auth/index.d.ts +0 -19
  379. package/dist/routes/auth/index.js +0 -64
  380. package/dist/routes/auth/logout.d.ts +0 -31
  381. package/dist/routes/auth/logout.js +0 -98
  382. package/dist/routes/auth/nextauth.d.ts +0 -22
  383. package/dist/routes/auth/nextauth.js +0 -40
  384. package/dist/routes/auth/refresh.d.ts +0 -30
  385. package/dist/routes/auth/refresh.js +0 -51
  386. package/dist/routes/auth/session.d.ts +0 -43
  387. package/dist/routes/auth/session.js +0 -157
  388. package/dist/routes/auth/settings.d.ts +0 -25
  389. package/dist/routes/auth/settings.js +0 -55
  390. package/dist/routes/auth/viability.d.ts +0 -52
  391. package/dist/routes/auth/viability.js +0 -190
  392. package/dist/routes/index.d.ts +0 -12
  393. package/dist/routes/index.js +0 -54
  394. package/dist/routes/session/index.d.ts +0 -6
  395. package/dist/routes/session/index.js +0 -10
  396. package/dist/routes/session/refresh-viability.d.ts +0 -16
  397. package/dist/routes/session/refresh-viability.js +0 -20
  398. package/dist/server/auth-guard.d.ts +0 -46
  399. package/dist/server/auth-guard.js +0 -128
  400. package/dist/server/auth.d.ts +0 -50
  401. package/dist/server/auth.js +0 -62
  402. package/dist/server/decode-session.d.ts +0 -30
  403. package/dist/server/decode-session.js +0 -78
  404. package/dist/server/slim-middleware.d.ts +0 -23
  405. package/dist/server/slim-middleware.js +0 -89
  406. package/dist/server/with-auth.d.ts +0 -33
  407. package/dist/server/with-auth.js +0 -59
  408. package/dist/services/signalrActivityService.d.ts +0 -44
  409. package/dist/services/signalrActivityService.js +0 -257
  410. package/dist/stores/authStore.d.ts +0 -154
  411. package/dist/stores/authStore.js +0 -1527
  412. package/dist/theme/ThemeProvider.d.ts +0 -14
  413. package/dist/theme/ThemeProvider.js +0 -28
  414. package/dist/theme/default.d.ts +0 -8
  415. package/dist/theme/default.js +0 -33
  416. package/dist/theme/index.d.ts +0 -15
  417. package/dist/theme/index.js +0 -25
  418. package/dist/theme/types.d.ts +0 -56
  419. package/dist/theme/types.js +0 -8
  420. package/dist/theme/useTheme.d.ts +0 -60
  421. package/dist/theme/useTheme.js +0 -63
  422. package/dist/theme/utils.d.ts +0 -13
  423. package/dist/theme/utils.js +0 -39
  424. package/dist/types/api.d.ts +0 -134
  425. package/dist/types/api.js +0 -44
  426. package/dist/types/auth.d.ts +0 -19
  427. package/dist/types/auth.js +0 -2
  428. package/dist/types/logging.d.ts +0 -42
  429. package/dist/types/logging.js +0 -2
  430. package/dist/types/recovery.d.ts +0 -48
  431. package/dist/types/recovery.js +0 -2
  432. package/dist/types/security.d.ts +0 -1
  433. package/dist/types/security.js +0 -2
  434. package/dist/utils/api.d.ts +0 -85
  435. package/dist/utils/api.js +0 -287
  436. package/dist/utils/circuitBreaker.d.ts +0 -43
  437. package/dist/utils/circuitBreaker.js +0 -91
  438. package/dist/utils/error-message.d.ts +0 -1
  439. package/dist/utils/error-message.js +0 -103
  440. package/dist/utils/layout/reservedSpace.d.ts +0 -59
  441. package/dist/utils/layout/reservedSpace.js +0 -102
  442. package/dist/utils/logout.d.ts +0 -14
  443. package/dist/utils/logout.js +0 -32
  444. package/dist/vibe/client.d.ts +0 -261
  445. package/dist/vibe/client.js +0 -445
  446. package/dist/vibe/enterprise-auth.d.ts +0 -106
  447. package/dist/vibe/enterprise-auth.js +0 -173
  448. package/dist/vibe/errors.d.ts +0 -83
  449. package/dist/vibe/errors.js +0 -146
  450. package/dist/vibe/generic.d.ts +0 -234
  451. package/dist/vibe/generic.js +0 -369
  452. package/dist/vibe/hooks/index.d.ts +0 -169
  453. package/dist/vibe/hooks/index.js +0 -252
  454. package/dist/vibe/index.d.ts +0 -25
  455. package/dist/vibe/index.js +0 -72
  456. package/dist/vibe/sessions.d.ts +0 -161
  457. package/dist/vibe/sessions.js +0 -391
  458. package/dist/vibe/types.d.ts +0 -353
  459. package/dist/vibe/types.js +0 -315
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@payez/next-mvp",
3
- "version": "4.0.0",
3
+ "version": "4.0.1",
4
4
  "sideEffects": false,
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
@@ -47,11 +47,6 @@
47
47
  "require": "./dist/types/auth.js",
48
48
  "default": "./dist/types/auth.js"
49
49
  },
50
- "./auth/auth-options": {
51
- "types": "./dist/auth/auth-options.d.ts",
52
- "require": "./dist/auth/auth-options.js",
53
- "default": "./dist/auth/auth-options.js"
54
- },
55
50
  "./auth/better-auth": {
56
51
  "types": "./dist/auth/better-auth.d.ts",
57
52
  "require": "./dist/auth/better-auth.js",
@@ -152,11 +147,6 @@
152
147
  "require": "./dist/lib/jwt-decode.js",
153
148
  "default": "./dist/lib/jwt-decode.js"
154
149
  },
155
- "./lib/nextauth-secret": {
156
- "types": "./dist/lib/nextauth-secret.d.ts",
157
- "require": "./dist/lib/nextauth-secret.js",
158
- "default": "./dist/lib/nextauth-secret.js"
159
- },
160
150
  "./lib/api-handler": {
161
151
  "types": "./dist/lib/api-handler.d.ts",
162
152
  "require": "./dist/lib/api-handler.js",
@@ -232,11 +222,6 @@
232
222
  "require": "./dist/lib/jwt-decode.js",
233
223
  "default": "./lib/jwt-decode.js"
234
224
  },
235
- "./dist/lib/nextauth-secret": {
236
- "types": "./lib/nextauth-secret.d.ts",
237
- "require": "./dist/lib/nextauth-secret.js",
238
- "default": "./lib/nextauth-secret.js"
239
- },
240
225
  "./dist/lib/token-expiry": {
241
226
  "types": "./lib/token-expiry.d.ts",
242
227
  "require": "./dist/lib/token-expiry.js",
@@ -837,6 +822,11 @@
837
822
  "require": "./dist/pages/coming-soon/page.js",
838
823
  "default": "./dist/pages/coming-soon/page.js"
839
824
  },
825
+ "./server/auth": {
826
+ "types": "./dist/server/auth.d.ts",
827
+ "require": "./dist/server/auth.js",
828
+ "default": "./dist/server/auth.js"
829
+ },
840
830
  "./server/auth-guard": {
841
831
  "types": "./dist/server/auth-guard.d.ts",
842
832
  "require": "./dist/server/auth-guard.js",
@@ -1,66 +0,0 @@
1
- /**
2
- * Enhanced Auth Handler with Coordinated Token Refresh
3
- *
4
- * Provides a middleware wrapper that automatically handles token lifecycle:
5
- * - Checks token expiry before each request
6
- * - Automatically refreshes expired or near-expired tokens
7
- * - Uses Redis locks for coordinated refresh (prevents race conditions)
8
- * - Retries requests on 401 responses with fresh tokens
9
- *
10
- * Pattern ported from website-membership simple-api-handler.ts
11
- *
12
- * @version 2.1.0
13
- * @since auth-ready-v2
14
- */
15
- import { NextRequest, NextResponse } from 'next/server';
16
- export interface AuthContext {
17
- token: any;
18
- accessToken: string;
19
- userId: string;
20
- sessionToken: string;
21
- refreshToken?: string;
22
- }
23
- export interface AuthHandlerOptions {
24
- /** Whether authentication is required for this route (default: true) */
25
- requireAuth?: boolean;
26
- /** Automatically refresh expired or near-expired tokens (default: true) */
27
- autoRefresh?: boolean;
28
- /** Buffer time in seconds before token expiry to trigger refresh (default: 300 = 5 minutes) */
29
- refreshBuffer?: number;
30
- /** Retry request on 401 response after refreshing token (default: true) */
31
- retryOn401?: boolean;
32
- /** Maximum number of retry attempts on 401 (default: 1) */
33
- maxRetries?: number;
34
- /** NextAuth secret for JWT decoding */
35
- nextAuthSecret?: string;
36
- /** IDP base URL for refresh requests */
37
- idpBaseUrl?: string;
38
- /** OAuth client ID */
39
- clientId?: string;
40
- }
41
- export type HandlerFunction = (req: NextRequest, context: any, auth: AuthContext) => Promise<NextResponse | Response>;
42
- /**
43
- * Creates an auth-aware handler with automatic token refresh
44
- *
45
- * @example
46
- * ```typescript
47
- * import { createAuthHandler } from '@payez/next-mvp/api';
48
- *
49
- * const handler = createAuthHandler({ requireAuth: true });
50
- *
51
- * export const GET = handler.handle(async (req, context, auth) => {
52
- * // auth.accessToken is guaranteed to be fresh
53
- * const response = await fetch('https://api.example.com/data', {
54
- * headers: { 'Authorization': `Bearer ${auth.accessToken}` }
55
- * });
56
- * return NextResponse.json(await response.json());
57
- * });
58
- * ```
59
- */
60
- export declare function createAuthHandler(options?: AuthHandlerOptions): {
61
- handle: (handler: HandlerFunction) => (req: NextRequest, context?: any) => Promise<Response>;
62
- };
63
- /**
64
- * Default export for convenience
65
- */
66
- export default createAuthHandler;
@@ -1,397 +0,0 @@
1
- "use strict";
2
- /**
3
- * Enhanced Auth Handler with Coordinated Token Refresh
4
- *
5
- * Provides a middleware wrapper that automatically handles token lifecycle:
6
- * - Checks token expiry before each request
7
- * - Automatically refreshes expired or near-expired tokens
8
- * - Uses Redis locks for coordinated refresh (prevents race conditions)
9
- * - Retries requests on 401 responses with fresh tokens
10
- *
11
- * Pattern ported from website-membership simple-api-handler.ts
12
- *
13
- * @version 2.1.0
14
- * @since auth-ready-v2
15
- */
16
- Object.defineProperty(exports, "__esModule", { value: true });
17
- exports.createAuthHandler = createAuthHandler;
18
- const server_1 = require("next/server");
19
- const auth_1 = require("../server/auth");
20
- const nanoid_1 = require("nanoid");
21
- const session_store_1 = require("../lib/session-store");
22
- /**
23
- * Creates an auth-aware handler with automatic token refresh
24
- *
25
- * @example
26
- * ```typescript
27
- * import { createAuthHandler } from '@payez/next-mvp/api';
28
- *
29
- * const handler = createAuthHandler({ requireAuth: true });
30
- *
31
- * export const GET = handler.handle(async (req, context, auth) => {
32
- * // auth.accessToken is guaranteed to be fresh
33
- * const response = await fetch('https://api.example.com/data', {
34
- * headers: { 'Authorization': `Bearer ${auth.accessToken}` }
35
- * });
36
- * return NextResponse.json(await response.json());
37
- * });
38
- * ```
39
- */
40
- function createAuthHandler(options = {}) {
41
- const { requireAuth = true, autoRefresh = true, refreshBuffer = 60, // 60 seconds - matches website-membership proven threshold
42
- retryOn401 = true, maxRetries = 1, nextAuthSecret = process.env.NEXTAUTH_SECRET, idpBaseUrl = process.env.IDP_URL, clientId = process.env.CLIENT_ID || process.env.NEXT_PUBLIC_IDP_CLIENT_ID } = options;
43
- /**
44
- * Performs coordinated token refresh with Redis locking
45
- * This prevents multiple concurrent requests from all trying to refresh simultaneously
46
- */
47
- async function performCoordinatedRefresh(sessionToken, requestId) {
48
- // Check if refresh is already in progress
49
- const existingLock = await (0, session_store_1.checkRefreshLock)(sessionToken);
50
- if (existingLock) {
51
- console.info('[AUTH_HANDLER] Refresh already in progress, waiting...', {
52
- requestId,
53
- lockOwner: existingLock.acquiredBy,
54
- lockAge: Date.now() - existingLock.acquiredAt
55
- });
56
- // Wait for the refresh to complete
57
- const waitResult = await waitForRefreshCompletion(sessionToken, requestId, 10000);
58
- if (waitResult.success) {
59
- // Get the fresh token from session
60
- const freshSession = await (0, session_store_1.getSession)(sessionToken);
61
- if (freshSession?.accessToken) {
62
- return {
63
- success: true,
64
- accessToken: freshSession.accessToken,
65
- refreshToken: freshSession.refreshToken,
66
- expiresIn: freshSession.accessTokenExpires
67
- ? Math.floor((freshSession.accessTokenExpires - Date.now()) / 1000)
68
- : undefined
69
- };
70
- }
71
- }
72
- return { success: false, error: waitResult.reason || 'Wait for refresh failed' };
73
- }
74
- // Try to acquire the refresh lock
75
- const lockAcquired = await (0, session_store_1.acquireRefreshLock)(sessionToken, requestId, 5000);
76
- if (!lockAcquired) {
77
- // Another request grabbed the lock, wait for it
78
- console.info('[AUTH_HANDLER] Failed to acquire lock, waiting for other request', { requestId });
79
- const waitResult = await waitForRefreshCompletion(sessionToken, requestId, 10000);
80
- if (waitResult.success) {
81
- const freshSession = await (0, session_store_1.getSession)(sessionToken);
82
- if (freshSession?.accessToken) {
83
- return {
84
- success: true,
85
- accessToken: freshSession.accessToken,
86
- refreshToken: freshSession.refreshToken
87
- };
88
- }
89
- }
90
- return { success: false, error: waitResult.reason || 'Wait for refresh failed' };
91
- }
92
- try {
93
- // Double-check if tokens are still stale after acquiring lock
94
- const latestSession = await (0, session_store_1.getSession)(sessionToken);
95
- if (latestSession && !tokenNeedsRefresh(latestSession, refreshBuffer)) {
96
- console.info('[AUTH_HANDLER] Tokens already fresh after acquiring lock, skipping refresh', { requestId });
97
- return {
98
- success: true,
99
- accessToken: latestSession.accessToken,
100
- refreshToken: latestSession.refreshToken
101
- };
102
- }
103
- // Actually perform the refresh
104
- return await executeRefresh(sessionToken, latestSession);
105
- }
106
- finally {
107
- // Always release the lock
108
- await (0, session_store_1.releaseRefreshLock)(sessionToken, requestId);
109
- }
110
- }
111
- /**
112
- * Wait for an in-progress refresh to complete
113
- */
114
- async function waitForRefreshCompletion(sessionToken, requestId, maxWaitMs) {
115
- const startTime = Date.now();
116
- const pollInterval = 100;
117
- while (Date.now() - startTime < maxWaitMs) {
118
- const lockExists = await (0, session_store_1.checkRefreshLock)(sessionToken);
119
- if (!lockExists) {
120
- // Lock released, check if tokens are fresh
121
- const session = await (0, session_store_1.getSession)(sessionToken);
122
- if (session?.accessToken && !tokenNeedsRefresh(session, refreshBuffer)) {
123
- return { success: true };
124
- }
125
- else {
126
- return { success: false, reason: 'Lock released but tokens not fresh' };
127
- }
128
- }
129
- await new Promise(resolve => setTimeout(resolve, pollInterval));
130
- }
131
- return { success: false, reason: `Timeout waiting for refresh (${maxWaitMs}ms)` };
132
- }
133
- /**
134
- * Check if token needs refresh based on expiry and buffer
135
- */
136
- function tokenNeedsRefresh(session, bufferSeconds) {
137
- if (!session.accessToken)
138
- return true;
139
- const expires = session.accessTokenExpires || 0;
140
- const bufferMs = bufferSeconds * 1000;
141
- const timeUntilExpiry = expires - Date.now();
142
- return timeUntilExpiry <= bufferMs;
143
- }
144
- /**
145
- * Execute the actual token refresh against IDP
146
- */
147
- async function executeRefresh(sessionToken, currentSession) {
148
- try {
149
- if (!idpBaseUrl || !clientId) {
150
- console.error('[AUTH_HANDLER] Missing IDP configuration for refresh');
151
- return { success: false, error: 'Missing IDP configuration' };
152
- }
153
- if (!currentSession) {
154
- console.error('[AUTH_HANDLER] No session found for refresh');
155
- return { success: false, error: 'No session found' };
156
- }
157
- if (!currentSession.refreshToken) {
158
- console.error('[AUTH_HANDLER] No refresh token available');
159
- return { success: false, error: 'No refresh token' };
160
- }
161
- // Extract authentication methods from session
162
- const authMethods = currentSession.authMethods ||
163
- (currentSession.token?.amr ? JSON.parse(currentSession.token.amr) : ['pwd', 'mfa']);
164
- const authLevel = String(currentSession.authenticationLevel || currentSession.token?.acr || '2');
165
- const twoFactorMethod = currentSession.twoFactorMethod || 'authenticator';
166
- // Build refresh request body
167
- const refreshRequestBody = {
168
- refresh_token: currentSession.refreshToken,
169
- amr: authMethods,
170
- acr: authLevel
171
- };
172
- if (currentSession.twoFactorComplete) {
173
- refreshRequestBody.two_factor_verified = true;
174
- }
175
- if (twoFactorMethod) {
176
- refreshRequestBody.two_factor_method = twoFactorMethod;
177
- }
178
- if (currentSession.mfaCompletedAt) {
179
- refreshRequestBody.two_factor_completed_at = new Date(currentSession.mfaCompletedAt).toISOString();
180
- }
181
- console.info('[AUTH_HANDLER] Executing refresh against IDP', {
182
- sessionToken: sessionToken.substring(0, 8) + '...',
183
- hasRefreshToken: true
184
- });
185
- const response = await fetch(`${idpBaseUrl}/api/ExternalAuth/refresh`, {
186
- method: 'POST',
187
- headers: {
188
- 'Content-Type': 'application/json',
189
- 'X-Client-Id': clientId,
190
- },
191
- body: JSON.stringify(refreshRequestBody),
192
- });
193
- if (!response.ok) {
194
- const errorText = await response.text().catch(() => 'Unknown error');
195
- console.error('[AUTH_HANDLER] Refresh failed:', response.status, errorText);
196
- return { success: false, error: `Refresh failed: ${response.status}` };
197
- }
198
- const data = await response.json();
199
- if (data.success === false) {
200
- return { success: false, error: data.error?.message || data.message || 'Refresh failed' };
201
- }
202
- const tokenData = data.data || data;
203
- if (!tokenData.access_token) {
204
- console.error('[AUTH_HANDLER] No access token in refresh response');
205
- return { success: false, error: 'No access token received' };
206
- }
207
- // Update session with new tokens
208
- const updatedSession = {
209
- ...currentSession,
210
- accessToken: tokenData.access_token,
211
- refreshToken: tokenData.refresh_token || currentSession.refreshToken,
212
- accessTokenExpires: tokenData.expires_in
213
- ? Date.now() + (tokenData.expires_in * 1000)
214
- : Date.now() + (3600 * 1000),
215
- };
216
- await (0, session_store_1.updateSession)(sessionToken, updatedSession);
217
- console.info('[AUTH_HANDLER] Token refresh successful', {
218
- newExpiry: new Date(updatedSession.accessTokenExpires).toISOString()
219
- });
220
- return {
221
- success: true,
222
- accessToken: tokenData.access_token,
223
- refreshToken: tokenData.refresh_token,
224
- expiresIn: tokenData.expires_in,
225
- };
226
- }
227
- catch (error) {
228
- console.error('[AUTH_HANDLER] Refresh exception:', error);
229
- return { success: false, error: error instanceof Error ? error.message : 'Refresh failed' };
230
- }
231
- }
232
- /**
233
- * Checks if auth context token needs refresh based on expiry and buffer
234
- */
235
- function needsRefresh(auth) {
236
- if (!autoRefresh)
237
- return false;
238
- // Check if we have token expiry information
239
- const token = auth.token;
240
- const expiresAt = token.accessTokenExpires || token.exp;
241
- if (!expiresAt) {
242
- // No expiry info, can't determine if refresh needed
243
- return false;
244
- }
245
- const now = Math.floor(Date.now() / 1000);
246
- const expiryTime = typeof expiresAt === 'number' && expiresAt > 1000000000000
247
- ? Math.floor(expiresAt / 1000) // Convert milliseconds to seconds
248
- : expiresAt;
249
- // Check if token expires within the buffer period
250
- return (expiryTime - now) <= refreshBuffer;
251
- }
252
- /**
253
- * Generate a unique request ID for coordinated refresh
254
- */
255
- function generateRequestId() {
256
- return (0, nanoid_1.nanoid)();
257
- }
258
- /**
259
- * Main handler wrapper
260
- */
261
- return {
262
- handle: (handler) => {
263
- return async (req, context = {}) => {
264
- // Extract session from Better Auth
265
- const betterAuthSession = await (0, auth_1.getSession)(req);
266
- const token = betterAuthSession ? { ...betterAuthSession.user, ...betterAuthSession.session } : null;
267
- // Check if auth is required
268
- if (requireAuth && !betterAuthSession) {
269
- return server_1.NextResponse.json({ error: 'Authentication required', code: 'UNAUTHORIZED' }, { status: 401 });
270
- }
271
- // If no session and auth not required, call handler without auth context
272
- if (!betterAuthSession) {
273
- return handler(req, context, null);
274
- }
275
- // Validate client_slug (token confusion attack prevention)
276
- // SECURITY: Fail closed - require configuration to be explicitly set
277
- const expectedClientSlug = process.env.NEXT_PUBLIC_EXPECTED_CLIENT_SLUG;
278
- if (!expectedClientSlug) {
279
- console.error('[AUTH_HANDLER] SECURITY MISCONFIGURATION: NEXT_PUBLIC_EXPECTED_CLIENT_SLUG not set');
280
- return server_1.NextResponse.json({
281
- error: 'Server configuration error',
282
- code: 'SECURITY_CONFIGURATION_MISSING'
283
- }, { status: 500 });
284
- }
285
- // Extract client_slug from token (normalize property name)
286
- const tokenClientSlug = token.client_slug || token.clientSlug;
287
- // SECURITY: Require client_slug claim in all tokens (no backward compat)
288
- if (!tokenClientSlug) {
289
- console.warn('[AUTH_HANDLER] Token missing required client_slug claim');
290
- return server_1.NextResponse.json({
291
- error: 'Token missing required claim',
292
- code: 'TOKEN_MISSING_CLIENT_SLUG'
293
- }, { status: 401 });
294
- }
295
- // SECURITY: Case-insensitive comparison to avoid casing attacks
296
- if (tokenClientSlug.toLowerCase() !== expectedClientSlug.toLowerCase()) {
297
- // Log without exposing sensitive details
298
- console.warn('[AUTH_HANDLER] Token client mismatch detected');
299
- return server_1.NextResponse.json({
300
- error: 'Token issued for different client',
301
- code: 'TOKEN_CLIENT_MISMATCH'
302
- }, { status: 401 });
303
- }
304
- // Build initial auth context
305
- let authContext = {
306
- token,
307
- accessToken: token.accessToken || '',
308
- userId: betterAuthSession.user?.id || token.userId || '',
309
- sessionToken: betterAuthSession.session?.token || '',
310
- refreshToken: token.refreshToken,
311
- };
312
- // Check if token needs refresh
313
- if (needsRefresh(authContext) && authContext.refreshToken) {
314
- const requestId = generateRequestId();
315
- console.info('[AUTH_HANDLER] Token near expiry, initiating coordinated refresh', {
316
- requestId,
317
- sessionToken: authContext.sessionToken.substring(0, 8) + '...'
318
- });
319
- const refreshResult = await performCoordinatedRefresh(authContext.sessionToken, requestId);
320
- if (refreshResult.success && refreshResult.accessToken) {
321
- // Update auth context with fresh token
322
- authContext.accessToken = refreshResult.accessToken;
323
- if (refreshResult.refreshToken) {
324
- authContext.refreshToken = refreshResult.refreshToken;
325
- }
326
- // Update token object for future checks
327
- authContext.token.accessToken = refreshResult.accessToken;
328
- if (refreshResult.expiresIn) {
329
- authContext.token.accessTokenExpires = Date.now() + (refreshResult.expiresIn * 1000);
330
- }
331
- console.info('[AUTH_HANDLER] Coordinated refresh successful', { requestId });
332
- }
333
- else {
334
- console.warn('[AUTH_HANDLER] Failed to refresh token:', refreshResult.error);
335
- // Continue with potentially expired token - handler may still succeed
336
- }
337
- }
338
- // Attach auth context to request for downstream use (following existing pattern)
339
- // IMPORTANT: Set this ONCE before the retry loop to avoid overwriting with stale data
340
- req.__authContext = {
341
- accessToken: authContext.accessToken,
342
- userId: authContext.userId,
343
- sessionToken: authContext.sessionToken,
344
- };
345
- // Call the actual handler
346
- let response;
347
- let retryCount = 0;
348
- while (retryCount <= maxRetries) {
349
- try {
350
- response = await handler(req, context, authContext);
351
- // Check if we got a 401 and should retry
352
- if (response.status === 401 &&
353
- retryOn401 &&
354
- retryCount < maxRetries &&
355
- authContext.refreshToken) {
356
- const retryRequestId = generateRequestId();
357
- console.info('[AUTH_HANDLER] Got 401, attempting coordinated refresh and retry', { retryRequestId });
358
- const refreshResult = await performCoordinatedRefresh(authContext.sessionToken, retryRequestId);
359
- if (refreshResult.success && refreshResult.accessToken) {
360
- console.info('[AUTH_HANDLER] Refresh succeeded, updating tokens', { retryRequestId });
361
- // Update auth context with fresh token
362
- authContext.accessToken = refreshResult.accessToken;
363
- if (refreshResult.refreshToken) {
364
- authContext.refreshToken = refreshResult.refreshToken;
365
- }
366
- // Update request context
367
- req.__authContext.accessToken = refreshResult.accessToken;
368
- console.info('[AUTH_HANDLER] Updated req.__authContext with new token, retrying request', { retryRequestId });
369
- retryCount++;
370
- continue; // Retry the request
371
- }
372
- else {
373
- console.warn('[AUTH_HANDLER] Refresh failed on 401 retry:', refreshResult.error);
374
- break; // Don't retry if refresh failed
375
- }
376
- }
377
- // Success or non-401 error - return response
378
- break;
379
- }
380
- catch (error) {
381
- // Handler threw an error
382
- console.error('[AUTH_HANDLER] Handler error:', error);
383
- return server_1.NextResponse.json({
384
- error: 'Internal server error',
385
- details: error instanceof Error ? error.message : 'Unknown error'
386
- }, { status: 500 });
387
- }
388
- }
389
- return response;
390
- };
391
- }
392
- };
393
- }
394
- /**
395
- * Default export for convenience
396
- */
397
- exports.default = createAuthHandler;
@@ -1,10 +0,0 @@
1
- /**
2
- * @payez/next-mvp API Module Exports
3
- *
4
- * Provides enhanced API route handlers with automatic token management
5
- *
6
- * @version 2.0.0
7
- * @since auth-ready-v2
8
- */
9
- export { createAuthHandler, type AuthContext, type AuthHandlerOptions, type HandlerFunction } from './auth-handler';
10
- export { default } from './auth-handler';
package/dist/api/index.js DELETED
@@ -1,19 +0,0 @@
1
- "use strict";
2
- /**
3
- * @payez/next-mvp API Module Exports
4
- *
5
- * Provides enhanced API route handlers with automatic token management
6
- *
7
- * @version 2.0.0
8
- * @since auth-ready-v2
9
- */
10
- var __importDefault = (this && this.__importDefault) || function (mod) {
11
- return (mod && mod.__esModule) ? mod : { "default": mod };
12
- };
13
- Object.defineProperty(exports, "__esModule", { value: true });
14
- exports.default = exports.createAuthHandler = void 0;
15
- var auth_handler_1 = require("./auth-handler");
16
- Object.defineProperty(exports, "createAuthHandler", { enumerable: true, get: function () { return auth_handler_1.createAuthHandler; } });
17
- // Default export for convenience
18
- var auth_handler_2 = require("./auth-handler");
19
- Object.defineProperty(exports, "default", { enumerable: true, get: function () { return __importDefault(auth_handler_2).default; } });
@@ -1,9 +0,0 @@
1
- import { NextRequest, NextResponse } from 'next/server';
2
- export declare function POST(req: NextRequest): Promise<NextResponse<{
3
- success: boolean;
4
- message: string;
5
- }> | NextResponse<{
6
- success: boolean;
7
- message: any;
8
- request_id: string;
9
- }>>;
@@ -1,110 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.POST = POST;
4
- const server_1 = require("next/server");
5
- const auth_1 = require("../../server/auth");
6
- const session_store_1 = require("../../lib/session-store");
7
- const nanoid_1 = require("nanoid");
8
- // ...
9
- async function POST(req) {
10
- const requestId = (0, nanoid_1.nanoid)();
11
- try {
12
- // Get session from Better Auth
13
- const betterAuthSession = await (0, auth_1.getSession)(req);
14
- const sessionToken = betterAuthSession?.session?.token;
15
- if (!betterAuthSession || typeof sessionToken !== 'string') {
16
- return server_1.NextResponse.json({ success: false, message: 'Unauthorized' }, { status: 401 });
17
- }
18
- const sessionData = await (0, session_store_1.getSession)(sessionToken);
19
- // NOTE: Field is idpAccessToken (not accessToken) per normalized naming convention
20
- if (!sessionData?.idpAccessToken) {
21
- return server_1.NextResponse.json({
22
- success: false,
23
- message: 'Authentication required - no access token available',
24
- error_code: 'UNAUTHORIZED',
25
- request_id: requestId,
26
- }, { status: 401 });
27
- }
28
- const body = await req.json();
29
- const { current_password, new_password, confirm_password } = body;
30
- // Validate input
31
- if (!current_password || !new_password || !confirm_password) {
32
- return server_1.NextResponse.json({
33
- success: false,
34
- message: 'Current password, new password, and confirmation are required',
35
- error_code: 'VALIDATION_ERROR',
36
- request_id: requestId,
37
- }, { status: 400 });
38
- }
39
- if (new_password !== confirm_password) {
40
- return server_1.NextResponse.json({
41
- success: false,
42
- message: 'New password and confirmation do not match',
43
- error_code: 'VALIDATION_ERROR',
44
- request_id: requestId,
45
- }, { status: 400 });
46
- }
47
- // Get IDP base URL from environment
48
- const idpBaseUrl = process.env.IDP_URL;
49
- if (!idpBaseUrl) {
50
- console.error('[CHANGE_PASSWORD] IDP_URL not configured');
51
- return server_1.NextResponse.json({
52
- success: false,
53
- message: 'Service configuration error',
54
- error_code: 'CONFIGURATION_ERROR',
55
- request_id: requestId,
56
- }, { status: 500 });
57
- }
58
- // Proxy request to IDP
59
- const idpUrl = `${idpBaseUrl}/api/Account/change-password`;
60
- const idpResponse = await fetch(idpUrl, {
61
- method: 'POST',
62
- headers: {
63
- 'Content-Type': 'application/json',
64
- 'Authorization': `Bearer ${sessionData.idpAccessToken}`,
65
- 'x-request-id': requestId,
66
- },
67
- body: JSON.stringify({
68
- current_password,
69
- new_password,
70
- confirm_password,
71
- }),
72
- });
73
- const responseData = await idpResponse.json().catch(() => ({}));
74
- if (!idpResponse.ok) {
75
- // Extract error message from IDP response
76
- let errorMessage = 'Failed to change password';
77
- if (responseData.message) {
78
- errorMessage = responseData.message;
79
- }
80
- else if (responseData.details?.value && Array.isArray(responseData.details.value) && responseData.details.value.length > 0) {
81
- errorMessage = responseData.details.value[0].message || errorMessage;
82
- }
83
- else if (responseData.details?.message) {
84
- errorMessage = responseData.details.message;
85
- }
86
- return server_1.NextResponse.json({
87
- success: false,
88
- message: errorMessage,
89
- error_code: responseData.error_code || 'CHANGE_PASSWORD_FAILED',
90
- request_id: requestId,
91
- details: responseData.details,
92
- }, { status: idpResponse.status });
93
- }
94
- return server_1.NextResponse.json({
95
- success: true,
96
- message: responseData.message || 'Password changed successfully',
97
- request_id: requestId,
98
- });
99
- }
100
- catch (error) {
101
- console.error('[CHANGE_PASSWORD] Error:', error);
102
- const requestId = req.headers.get('x-request-id') ?? crypto.randomUUID();
103
- return server_1.NextResponse.json({
104
- success: false,
105
- message: error instanceof Error ? error.message : 'Failed to change password',
106
- error_code: 'INTERNAL_ERROR',
107
- request_id: requestId,
108
- }, { status: 500 });
109
- }
110
- }
@@ -1,2 +0,0 @@
1
- import { NextRequest, NextResponse } from 'next/server';
2
- export declare function POST(req: NextRequest): Promise<NextResponse<any>>;