@payez/next-mvp 3.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +782 -0
- package/dist/api/auth-handler.d.ts +67 -0
- package/dist/api/auth-handler.js +397 -0
- package/dist/api/index.d.ts +10 -0
- package/dist/api/index.js +19 -0
- package/dist/api-handlers/account/change-password.d.ts +9 -0
- package/dist/api-handlers/account/change-password.js +112 -0
- package/dist/api-handlers/account/masked-info.d.ts +2 -0
- package/dist/api-handlers/account/masked-info.js +41 -0
- package/dist/api-handlers/account/profile.d.ts +3 -0
- package/dist/api-handlers/account/profile.js +63 -0
- package/dist/api-handlers/account/recovery/initiate.d.ts +2 -0
- package/dist/api-handlers/account/recovery/initiate.js +26 -0
- package/dist/api-handlers/account/recovery/send-code.d.ts +2 -0
- package/dist/api-handlers/account/recovery/send-code.js +28 -0
- package/dist/api-handlers/account/recovery/verify-code.d.ts +2 -0
- package/dist/api-handlers/account/recovery/verify-code.js +28 -0
- package/dist/api-handlers/account/reset-password.d.ts +2 -0
- package/dist/api-handlers/account/reset-password.js +26 -0
- package/dist/api-handlers/account/send-code.d.ts +24 -0
- package/dist/api-handlers/account/send-code.js +60 -0
- package/dist/api-handlers/account/update-phone.d.ts +27 -0
- package/dist/api-handlers/account/update-phone.js +64 -0
- package/dist/api-handlers/account/validate-password.d.ts +17 -0
- package/dist/api-handlers/account/validate-password.js +81 -0
- package/dist/api-handlers/account/verify-email.d.ts +26 -0
- package/dist/api-handlers/account/verify-email.js +106 -0
- package/dist/api-handlers/account/verify-sms.d.ts +26 -0
- package/dist/api-handlers/account/verify-sms.js +106 -0
- package/dist/api-handlers/admin/analytics.d.ts +20 -0
- package/dist/api-handlers/admin/analytics.js +379 -0
- package/dist/api-handlers/admin/audit.d.ts +20 -0
- package/dist/api-handlers/admin/audit.js +214 -0
- package/dist/api-handlers/admin/index.d.ts +21 -0
- package/dist/api-handlers/admin/index.js +41 -0
- package/dist/api-handlers/admin/redis-sessions.d.ts +36 -0
- package/dist/api-handlers/admin/redis-sessions.js +204 -0
- package/dist/api-handlers/admin/sessions.d.ts +21 -0
- package/dist/api-handlers/admin/sessions.js +284 -0
- package/dist/api-handlers/admin/site-logs.d.ts +46 -0
- package/dist/api-handlers/admin/site-logs.js +318 -0
- package/dist/api-handlers/admin/users.d.ts +20 -0
- package/dist/api-handlers/admin/users.js +222 -0
- package/dist/api-handlers/admin/vibe-data.d.ts +80 -0
- package/dist/api-handlers/admin/vibe-data.js +268 -0
- package/dist/api-handlers/anon/preferences.d.ts +37 -0
- package/dist/api-handlers/anon/preferences.js +96 -0
- package/dist/api-handlers/auth/jwks.d.ts +2 -0
- package/dist/api-handlers/auth/jwks.js +24 -0
- package/dist/api-handlers/auth/login.d.ts +42 -0
- package/dist/api-handlers/auth/login.js +178 -0
- package/dist/api-handlers/auth/refresh.d.ts +74 -0
- package/dist/api-handlers/auth/refresh.js +635 -0
- package/dist/api-handlers/auth/signout.d.ts +37 -0
- package/dist/api-handlers/auth/signout.js +187 -0
- package/dist/api-handlers/auth/status.d.ts +8 -0
- package/dist/api-handlers/auth/status.js +26 -0
- package/dist/api-handlers/auth/update-session.d.ts +37 -0
- package/dist/api-handlers/auth/update-session.js +95 -0
- package/dist/api-handlers/auth/validate.d.ts +6 -0
- package/dist/api-handlers/auth/validate.js +43 -0
- package/dist/api-handlers/auth/verify-code.d.ts +43 -0
- package/dist/api-handlers/auth/verify-code.js +94 -0
- package/dist/api-handlers/session/refresh-viability.d.ts +14 -0
- package/dist/api-handlers/session/refresh-viability.js +39 -0
- package/dist/api-handlers/session/viability.d.ts +13 -0
- package/dist/api-handlers/session/viability.js +146 -0
- package/dist/api-handlers/test/force-expire.d.ts +23 -0
- package/dist/api-handlers/test/force-expire.js +65 -0
- package/dist/auth/auth-decision.d.ts +39 -0
- package/dist/auth/auth-decision.js +182 -0
- package/dist/auth/auth-options.d.ts +57 -0
- package/dist/auth/auth-options.js +213 -0
- package/dist/auth/callbacks/index.d.ts +6 -0
- package/dist/auth/callbacks/index.js +12 -0
- package/dist/auth/callbacks/jwt.d.ts +45 -0
- package/dist/auth/callbacks/jwt.js +305 -0
- package/dist/auth/callbacks/session.d.ts +60 -0
- package/dist/auth/callbacks/session.js +170 -0
- package/dist/auth/callbacks/signin.d.ts +23 -0
- package/dist/auth/callbacks/signin.js +44 -0
- package/dist/auth/events/index.d.ts +4 -0
- package/dist/auth/events/index.js +8 -0
- package/dist/auth/events/signout.d.ts +17 -0
- package/dist/auth/events/signout.js +32 -0
- package/dist/auth/providers/credentials.d.ts +32 -0
- package/dist/auth/providers/credentials.js +223 -0
- package/dist/auth/providers/index.d.ts +5 -0
- package/dist/auth/providers/index.js +21 -0
- package/dist/auth/providers/oauth.d.ts +26 -0
- package/dist/auth/providers/oauth.js +105 -0
- package/dist/auth/route-config.d.ts +66 -0
- package/dist/auth/route-config.js +190 -0
- package/dist/auth/types/auth-types.d.ts +417 -0
- package/dist/auth/types/auth-types.js +53 -0
- package/dist/auth/types/index.d.ts +6 -0
- package/dist/auth/types/index.js +22 -0
- package/dist/auth/unauthenticated-routes.d.ts +1 -0
- package/dist/auth/unauthenticated-routes.js +19 -0
- package/dist/auth/utils/idp-client.d.ts +94 -0
- package/dist/auth/utils/idp-client.js +383 -0
- package/dist/auth/utils/index.d.ts +5 -0
- package/dist/auth/utils/index.js +21 -0
- package/dist/auth/utils/token-utils.d.ts +84 -0
- package/dist/auth/utils/token-utils.js +219 -0
- package/dist/client/AuthContext.d.ts +19 -0
- package/dist/client/AuthContext.js +112 -0
- package/dist/client/fetch-with-auth.d.ts +11 -0
- package/dist/client/fetch-with-auth.js +44 -0
- package/dist/client/fetchWithSession.d.ts +3 -0
- package/dist/client/fetchWithSession.js +24 -0
- package/dist/client/index.d.ts +9 -0
- package/dist/client/index.js +20 -0
- package/dist/client/useAnonSession.d.ts +36 -0
- package/dist/client/useAnonSession.js +99 -0
- package/dist/components/SessionSync.d.ts +13 -0
- package/dist/components/SessionSync.js +119 -0
- package/dist/components/SignalRHealthCheck.d.ts +10 -0
- package/dist/components/SignalRHealthCheck.js +97 -0
- package/dist/components/account/UserAvatarMenu.d.ts +20 -0
- package/dist/components/account/UserAvatarMenu.js +80 -0
- package/dist/components/account/index.d.ts +7 -0
- package/dist/components/account/index.js +10 -0
- package/dist/components/admin/AlertSettingsTab.d.ts +48 -0
- package/dist/components/admin/AlertSettingsTab.js +351 -0
- package/dist/components/admin/AnalyticsTab.d.ts +22 -0
- package/dist/components/admin/AnalyticsTab.js +167 -0
- package/dist/components/admin/DataBrowserTab.d.ts +19 -0
- package/dist/components/admin/DataBrowserTab.js +252 -0
- package/dist/components/admin/LoggingSettingsTab.d.ts +73 -0
- package/dist/components/admin/LoggingSettingsTab.js +339 -0
- package/dist/components/admin/SessionsTab.d.ts +37 -0
- package/dist/components/admin/SessionsTab.js +165 -0
- package/dist/components/admin/StatsTab.d.ts +53 -0
- package/dist/components/admin/StatsTab.js +161 -0
- package/dist/components/admin/VibeAdminContext.d.ts +32 -0
- package/dist/components/admin/VibeAdminContext.js +38 -0
- package/dist/components/admin/VibeAdminLayout.d.ts +11 -0
- package/dist/components/admin/VibeAdminLayout.js +69 -0
- package/dist/components/admin/index.d.ts +29 -0
- package/dist/components/admin/index.js +44 -0
- package/dist/components/auth/FederatedAuthSection.d.ts +8 -0
- package/dist/components/auth/FederatedAuthSection.js +45 -0
- package/dist/components/auth/ModeAwareLoginPage.d.ts +10 -0
- package/dist/components/auth/ModeAwareLoginPage.js +42 -0
- package/dist/components/auth/ModeAwareSignupPage.d.ts +9 -0
- package/dist/components/auth/ModeAwareSignupPage.js +78 -0
- package/dist/components/auth/TraditionalAuthSection.d.ts +14 -0
- package/dist/components/auth/TraditionalAuthSection.js +20 -0
- package/dist/components/recovery/CompleteStep.d.ts +5 -0
- package/dist/components/recovery/CompleteStep.js +8 -0
- package/dist/components/recovery/InitiateRecoveryStep.d.ts +8 -0
- package/dist/components/recovery/InitiateRecoveryStep.js +20 -0
- package/dist/components/recovery/SelectMethodStep.d.ts +8 -0
- package/dist/components/recovery/SelectMethodStep.js +8 -0
- package/dist/components/recovery/SetPasswordStep.d.ts +6 -0
- package/dist/components/recovery/SetPasswordStep.js +20 -0
- package/dist/components/recovery/VerifyCodeStep.d.ts +10 -0
- package/dist/components/recovery/VerifyCodeStep.js +24 -0
- package/dist/components/reserved/ReservedRecoveryWarning.d.ts +38 -0
- package/dist/components/reserved/ReservedRecoveryWarning.js +92 -0
- package/dist/components/reserved/ReservedStatusBox.d.ts +30 -0
- package/dist/components/reserved/ReservedStatusBox.js +71 -0
- package/dist/components/ui/BetaBadge.d.ts +29 -0
- package/dist/components/ui/BetaBadge.js +38 -0
- package/dist/components/ui/Footer.d.ts +37 -0
- package/dist/components/ui/Footer.js +41 -0
- package/dist/config/env.d.ts +66 -0
- package/dist/config/env.js +57 -0
- package/dist/config/logger.d.ts +57 -0
- package/dist/config/logger.js +73 -0
- package/dist/config/logging-config.d.ts +30 -0
- package/dist/config/logging-config.js +122 -0
- package/dist/config/unauthenticated-routes.d.ts +17 -0
- package/dist/config/unauthenticated-routes.js +24 -0
- package/dist/config/vibe-log-transport.d.ts +79 -0
- package/dist/config/vibe-log-transport.js +203 -0
- package/dist/edge/internal-api-url.d.ts +53 -0
- package/dist/edge/internal-api-url.js +63 -0
- package/dist/edge/middleware.d.ts +14 -0
- package/dist/edge/middleware.js +32 -0
- package/dist/hooks/useAuth.d.ts +23 -0
- package/dist/hooks/useAuth.js +81 -0
- package/dist/hooks/useAuthSettings.d.ts +59 -0
- package/dist/hooks/useAuthSettings.js +93 -0
- package/dist/hooks/useAvailableProviders.d.ts +45 -0
- package/dist/hooks/useAvailableProviders.js +108 -0
- package/dist/hooks/usePasswordValidation.d.ts +27 -0
- package/dist/hooks/usePasswordValidation.js +102 -0
- package/dist/hooks/useProfile.d.ts +15 -0
- package/dist/hooks/useProfile.js +59 -0
- package/dist/hooks/usePublicAuthSettings.d.ts +56 -0
- package/dist/hooks/usePublicAuthSettings.js +131 -0
- package/dist/hooks/useSessionExpiration.d.ts +57 -0
- package/dist/hooks/useSessionExpiration.js +72 -0
- package/dist/hooks/useViabilitySession.d.ts +75 -0
- package/dist/hooks/useViabilitySession.js +268 -0
- package/dist/index.d.ts +12 -0
- package/dist/index.js +54 -0
- package/dist/lib/anon-session.d.ts +74 -0
- package/dist/lib/anon-session.js +169 -0
- package/dist/lib/api-handler.d.ts +123 -0
- package/dist/lib/api-handler.js +478 -0
- package/dist/lib/app-slug.d.ts +95 -0
- package/dist/lib/app-slug.js +172 -0
- package/dist/lib/demo-mode.d.ts +6 -0
- package/dist/lib/demo-mode.js +16 -0
- package/dist/lib/geolocation.d.ts +64 -0
- package/dist/lib/geolocation.js +235 -0
- package/dist/lib/idp-client-config.d.ts +75 -0
- package/dist/lib/idp-client-config.js +351 -0
- package/dist/lib/idp-fetch.d.ts +14 -0
- package/dist/lib/idp-fetch.js +91 -0
- package/dist/lib/internal-api.d.ts +87 -0
- package/dist/lib/internal-api.js +122 -0
- package/dist/lib/jwt-decode-client.d.ts +10 -0
- package/dist/lib/jwt-decode-client.js +46 -0
- package/dist/lib/jwt-decode.d.ts +48 -0
- package/dist/lib/jwt-decode.js +57 -0
- package/dist/lib/nextauth-secret.d.ts +10 -0
- package/dist/lib/nextauth-secret.js +104 -0
- package/dist/lib/rate-limit-service.d.ts +23 -0
- package/dist/lib/rate-limit-service.js +6 -0
- package/dist/lib/redis.d.ts +5 -0
- package/dist/lib/redis.js +28 -0
- package/dist/lib/refresh-token-validator.d.ts +13 -0
- package/dist/lib/refresh-token-validator.js +117 -0
- package/dist/lib/roles.d.ts +145 -0
- package/dist/lib/roles.js +168 -0
- package/dist/lib/secret-validation.d.ts +4 -0
- package/dist/lib/secret-validation.js +14 -0
- package/dist/lib/session-store.d.ts +166 -0
- package/dist/lib/session-store.js +537 -0
- package/dist/lib/session.d.ts +21 -0
- package/dist/lib/session.js +26 -0
- package/dist/lib/site-logger.d.ts +214 -0
- package/dist/lib/site-logger.js +210 -0
- package/dist/lib/standardized-client-api.d.ts +161 -0
- package/dist/lib/standardized-client-api.js +786 -0
- package/dist/lib/startup-init.d.ts +40 -0
- package/dist/lib/startup-init.js +261 -0
- package/dist/lib/test-aware-get-token.d.ts +2 -0
- package/dist/lib/test-aware-get-token.js +81 -0
- package/dist/lib/token-expiry.d.ts +14 -0
- package/dist/lib/token-expiry.js +39 -0
- package/dist/lib/token-lifecycle.d.ts +52 -0
- package/dist/lib/token-lifecycle.js +398 -0
- package/dist/lib/types/api-responses.d.ts +128 -0
- package/dist/lib/types/api-responses.js +171 -0
- package/dist/lib/user-agent-parser.d.ts +50 -0
- package/dist/lib/user-agent-parser.js +220 -0
- package/dist/logging/api/admin-analytics.d.ts +3 -0
- package/dist/logging/api/admin-analytics.js +45 -0
- package/dist/logging/api/audit-log.d.ts +3 -0
- package/dist/logging/api/audit-log.js +52 -0
- package/dist/logging/components/AdminAnalyticsLayout.d.ts +10 -0
- package/dist/logging/components/AdminAnalyticsLayout.js +11 -0
- package/dist/logging/components/AuditLogViewer.d.ts +7 -0
- package/dist/logging/components/AuditLogViewer.js +51 -0
- package/dist/logging/components/ErrorMetricsCard.d.ts +7 -0
- package/dist/logging/components/ErrorMetricsCard.js +16 -0
- package/dist/logging/components/HealthMetricsCard.d.ts +7 -0
- package/dist/logging/components/HealthMetricsCard.js +19 -0
- package/dist/logging/hooks/useAdminAnalytics.d.ts +24 -0
- package/dist/logging/hooks/useAdminAnalytics.js +22 -0
- package/dist/logging/hooks/useAuditLog.d.ts +6 -0
- package/dist/logging/hooks/useAuditLog.js +25 -0
- package/dist/logging/hooks/useErrorMetrics.d.ts +6 -0
- package/dist/logging/hooks/useErrorMetrics.js +38 -0
- package/dist/logging/hooks/useHealthMetrics.d.ts +6 -0
- package/dist/logging/hooks/useHealthMetrics.js +41 -0
- package/dist/logging/index.d.ts +11 -0
- package/dist/logging/index.js +40 -0
- package/dist/logging/types/analytics.d.ts +68 -0
- package/dist/logging/types/analytics.js +3 -0
- package/dist/logging/types/audit.d.ts +29 -0
- package/dist/logging/types/audit.js +2 -0
- package/dist/logging/types/index.d.ts +2 -0
- package/dist/logging/types/index.js +19 -0
- package/dist/middleware/auth-decision.d.ts +33 -0
- package/dist/middleware/auth-decision.js +65 -0
- package/dist/middleware/create-middleware.d.ts +100 -0
- package/dist/middleware/create-middleware.js +445 -0
- package/dist/middleware/rbac-check.d.ts +44 -0
- package/dist/middleware/rbac-check.js +191 -0
- package/dist/middleware/twofa-presets.d.ts +134 -0
- package/dist/middleware/twofa-presets.js +175 -0
- package/dist/models/DecodedAccessToken.d.ts +17 -0
- package/dist/models/DecodedAccessToken.js +2 -0
- package/dist/models/SessionModel.d.ts +122 -0
- package/dist/models/SessionModel.js +136 -0
- package/dist/pages/admin-login/page.d.ts +31 -0
- package/dist/pages/admin-login/page.js +83 -0
- package/dist/pages/admin-roles/RolesAdminPage.d.ts +15 -0
- package/dist/pages/admin-roles/RolesAdminPage.js +78 -0
- package/dist/pages/admin-roles/index.d.ts +8 -0
- package/dist/pages/admin-roles/index.js +15 -0
- package/dist/pages/admin-roles/modals.d.ts +72 -0
- package/dist/pages/admin-roles/modals.js +154 -0
- package/dist/pages/client-admin/ClientSiteAdminPage.d.ts +79 -0
- package/dist/pages/client-admin/ClientSiteAdminPage.js +177 -0
- package/dist/pages/client-admin/index.d.ts +32 -0
- package/dist/pages/client-admin/index.js +37 -0
- package/dist/pages/login/page.d.ts +22 -0
- package/dist/pages/login/page.js +239 -0
- package/dist/pages/profile/EnhancedProfilePage.d.ts +13 -0
- package/dist/pages/profile/EnhancedProfilePage.js +150 -0
- package/dist/pages/profile/index.d.ts +8 -0
- package/dist/pages/profile/index.js +16 -0
- package/dist/pages/profile/page.d.ts +19 -0
- package/dist/pages/profile/page.js +47 -0
- package/dist/pages/profile/profile-patch.d.ts +1 -0
- package/dist/pages/profile/profile-patch.js +281 -0
- package/dist/pages/recovery/page.d.ts +1 -0
- package/dist/pages/recovery/page.js +142 -0
- package/dist/pages/roles/MyRolesPage.d.ts +24 -0
- package/dist/pages/roles/MyRolesPage.js +71 -0
- package/dist/pages/roles/components.d.ts +63 -0
- package/dist/pages/roles/components.js +108 -0
- package/dist/pages/roles/index.d.ts +8 -0
- package/dist/pages/roles/index.js +19 -0
- package/dist/pages/security/EnhancedSecurityPage.d.ts +14 -0
- package/dist/pages/security/EnhancedSecurityPage.js +248 -0
- package/dist/pages/security/index.d.ts +8 -0
- package/dist/pages/security/index.js +16 -0
- package/dist/pages/security/page.d.ts +21 -0
- package/dist/pages/security/page.js +212 -0
- package/dist/pages/security/security-patch.d.ts +1 -0
- package/dist/pages/security/security-patch.js +302 -0
- package/dist/pages/settings/EnhancedSettingsPage.d.ts +46 -0
- package/dist/pages/settings/EnhancedSettingsPage.js +231 -0
- package/dist/pages/settings/index.d.ts +8 -0
- package/dist/pages/settings/index.js +16 -0
- package/dist/pages/settings/page.d.ts +7 -0
- package/dist/pages/settings/page.js +26 -0
- package/dist/pages/showcase/ShowcasePage.d.ts +13 -0
- package/dist/pages/showcase/ShowcasePage.js +140 -0
- package/dist/pages/showcase/index.d.ts +12 -0
- package/dist/pages/showcase/index.js +17 -0
- package/dist/pages/test-env/EmergencyLogoutPage.d.ts +14 -0
- package/dist/pages/test-env/EmergencyLogoutPage.js +98 -0
- package/dist/pages/test-env/JwtInspectPage.d.ts +14 -0
- package/dist/pages/test-env/JwtInspectPage.js +114 -0
- package/dist/pages/test-env/RefreshTokenPage.d.ts +15 -0
- package/dist/pages/test-env/RefreshTokenPage.js +91 -0
- package/dist/pages/test-env/TestEnvPage.d.ts +13 -0
- package/dist/pages/test-env/TestEnvPage.js +49 -0
- package/dist/pages/test-env/index.d.ts +24 -0
- package/dist/pages/test-env/index.js +32 -0
- package/dist/pages/verify-code/page.d.ts +30 -0
- package/dist/pages/verify-code/page.js +408 -0
- package/dist/routes/account/index.d.ts +28 -0
- package/dist/routes/account/index.js +71 -0
- package/dist/routes/account/masked-info.d.ts +33 -0
- package/dist/routes/account/masked-info.js +39 -0
- package/dist/routes/account/send-code.d.ts +37 -0
- package/dist/routes/account/send-code.js +42 -0
- package/dist/routes/account/update-phone.d.ts +13 -0
- package/dist/routes/account/update-phone.js +17 -0
- package/dist/routes/account/verify-email.d.ts +38 -0
- package/dist/routes/account/verify-email.js +43 -0
- package/dist/routes/account/verify-sms.d.ts +38 -0
- package/dist/routes/account/verify-sms.js +43 -0
- package/dist/routes/auth/index.d.ts +19 -0
- package/dist/routes/auth/index.js +64 -0
- package/dist/routes/auth/logout.d.ts +31 -0
- package/dist/routes/auth/logout.js +113 -0
- package/dist/routes/auth/nextauth.d.ts +19 -0
- package/dist/routes/auth/nextauth.js +72 -0
- package/dist/routes/auth/refresh.d.ts +30 -0
- package/dist/routes/auth/refresh.js +51 -0
- package/dist/routes/auth/session.d.ts +72 -0
- package/dist/routes/auth/session.js +180 -0
- package/dist/routes/auth/settings.d.ts +25 -0
- package/dist/routes/auth/settings.js +55 -0
- package/dist/routes/auth/viability.d.ts +52 -0
- package/dist/routes/auth/viability.js +201 -0
- package/dist/routes/index.d.ts +12 -0
- package/dist/routes/index.js +54 -0
- package/dist/routes/session/index.d.ts +6 -0
- package/dist/routes/session/index.js +10 -0
- package/dist/routes/session/refresh-viability.d.ts +16 -0
- package/dist/routes/session/refresh-viability.js +20 -0
- package/dist/services/signalrActivityService.d.ts +44 -0
- package/dist/services/signalrActivityService.js +257 -0
- package/dist/stores/authStore.d.ts +154 -0
- package/dist/stores/authStore.js +1531 -0
- package/dist/theme/ThemeProvider.d.ts +14 -0
- package/dist/theme/ThemeProvider.js +28 -0
- package/dist/theme/default.d.ts +8 -0
- package/dist/theme/default.js +33 -0
- package/dist/theme/index.d.ts +15 -0
- package/dist/theme/index.js +25 -0
- package/dist/theme/types.d.ts +56 -0
- package/dist/theme/types.js +8 -0
- package/dist/theme/useTheme.d.ts +60 -0
- package/dist/theme/useTheme.js +63 -0
- package/dist/theme/utils.d.ts +13 -0
- package/dist/theme/utils.js +39 -0
- package/dist/types/api.d.ts +134 -0
- package/dist/types/api.js +44 -0
- package/dist/types/auth.d.ts +19 -0
- package/dist/types/auth.js +2 -0
- package/dist/types/logging.d.ts +42 -0
- package/dist/types/logging.js +2 -0
- package/dist/types/recovery.d.ts +48 -0
- package/dist/types/recovery.js +2 -0
- package/dist/types/security.d.ts +1 -0
- package/dist/types/security.js +2 -0
- package/dist/utils/api.d.ts +85 -0
- package/dist/utils/api.js +287 -0
- package/dist/utils/circuitBreaker.d.ts +43 -0
- package/dist/utils/circuitBreaker.js +91 -0
- package/dist/utils/error-message.d.ts +1 -0
- package/dist/utils/error-message.js +103 -0
- package/dist/utils/layout/reservedSpace.d.ts +59 -0
- package/dist/utils/layout/reservedSpace.js +102 -0
- package/dist/utils/logout.d.ts +14 -0
- package/dist/utils/logout.js +32 -0
- package/dist/vibe/client.d.ts +261 -0
- package/dist/vibe/client.js +445 -0
- package/dist/vibe/errors.d.ts +83 -0
- package/dist/vibe/errors.js +146 -0
- package/dist/vibe/generic.d.ts +234 -0
- package/dist/vibe/generic.js +369 -0
- package/dist/vibe/hooks/index.d.ts +169 -0
- package/dist/vibe/hooks/index.js +252 -0
- package/dist/vibe/index.d.ts +23 -0
- package/dist/vibe/index.js +67 -0
- package/dist/vibe/sessions.d.ts +161 -0
- package/dist/vibe/sessions.js +391 -0
- package/dist/vibe/types.d.ts +353 -0
- package/dist/vibe/types.js +315 -0
- package/package.json +855 -0
- package/scripts/check-internal-url-usage.sh +73 -0
- package/scripts/dev-broker.ps1 +35 -0
- package/scripts/dev-local.ps1 +45 -0
- package/src/api/auth-handler.ts +550 -0
- package/src/api/index.ts +18 -0
- package/src/api-handlers/account/change-password.ts +145 -0
- package/src/api-handlers/account/masked-info.ts +45 -0
- package/src/api-handlers/account/profile.ts +80 -0
- package/src/api-handlers/account/recovery/initiate.ts +23 -0
- package/src/api-handlers/account/recovery/send-code.ts +25 -0
- package/src/api-handlers/account/recovery/verify-code.ts +25 -0
- package/src/api-handlers/account/reset-password.ts +23 -0
- package/src/api-handlers/account/send-code.ts +76 -0
- package/src/api-handlers/account/update-phone.ts +79 -0
- package/src/api-handlers/account/validate-password.ts +118 -0
- package/src/api-handlers/account/verify-email.ts +125 -0
- package/src/api-handlers/account/verify-sms.ts +125 -0
- package/src/api-handlers/admin/analytics.ts +445 -0
- package/src/api-handlers/admin/audit.ts +225 -0
- package/src/api-handlers/admin/index.ts +59 -0
- package/src/api-handlers/admin/redis-sessions.ts +253 -0
- package/src/api-handlers/admin/sessions.ts +320 -0
- package/src/api-handlers/admin/site-logs.ts +367 -0
- package/src/api-handlers/admin/users.ts +244 -0
- package/src/api-handlers/admin/vibe-data.ts +326 -0
- package/src/api-handlers/anon/preferences.ts +123 -0
- package/src/api-handlers/auth/jwks.ts +20 -0
- package/src/api-handlers/auth/login.ts +240 -0
- package/src/api-handlers/auth/refresh.ts +687 -0
- package/src/api-handlers/auth/signout.ts +212 -0
- package/src/api-handlers/auth/status.ts +23 -0
- package/src/api-handlers/auth/update-session.ts +125 -0
- package/src/api-handlers/auth/validate.ts +44 -0
- package/src/api-handlers/auth/verify-code.ts +129 -0
- package/src/api-handlers/session/refresh-viability.ts +36 -0
- package/src/api-handlers/session/viability.ts +166 -0
- package/src/api-handlers/test/force-expire.ts +67 -0
- package/src/auth/auth-decision.ts +230 -0
- package/src/auth/auth-options.ts +237 -0
- package/src/auth/callbacks/index.ts +7 -0
- package/src/auth/callbacks/jwt.ts +382 -0
- package/src/auth/callbacks/session.ts +243 -0
- package/src/auth/callbacks/signin.ts +56 -0
- package/src/auth/events/index.ts +5 -0
- package/src/auth/events/signout.ts +33 -0
- package/src/auth/providers/credentials.ts +256 -0
- package/src/auth/providers/index.ts +6 -0
- package/src/auth/providers/oauth.ts +114 -0
- package/src/auth/route-config.ts +220 -0
- package/src/auth/types/auth-types.ts +555 -0
- package/src/auth/types/index.ts +7 -0
- package/src/auth/unauthenticated-routes.ts +3 -0
- package/src/auth/utils/idp-client.ts +444 -0
- package/src/auth/utils/index.ts +6 -0
- package/src/auth/utils/token-utils.ts +244 -0
- package/src/client/AuthContext.tsx +140 -0
- package/src/client/fetch-with-auth.ts +48 -0
- package/src/client/fetchWithSession.ts +21 -0
- package/src/client/index.ts +13 -0
- package/src/client/useAnonSession.ts +131 -0
- package/src/components/SessionSync.tsx +137 -0
- package/src/components/SignalRHealthCheck.tsx +131 -0
- package/src/components/account/UserAvatarMenu.tsx +217 -0
- package/src/components/account/index.ts +8 -0
- package/src/components/admin/AlertSettingsTab.tsx +728 -0
- package/src/components/admin/AnalyticsTab.tsx +703 -0
- package/src/components/admin/DataBrowserTab.tsx +505 -0
- package/src/components/admin/LoggingSettingsTab.tsx +665 -0
- package/src/components/admin/SessionsTab.tsx +414 -0
- package/src/components/admin/StatsTab.tsx +379 -0
- package/src/components/admin/VibeAdminContext.tsx +87 -0
- package/src/components/admin/VibeAdminLayout.tsx +185 -0
- package/src/components/admin/index.ts +59 -0
- package/src/components/auth/FederatedAuthSection.tsx +95 -0
- package/src/components/auth/ModeAwareLoginPage.tsx +135 -0
- package/src/components/auth/ModeAwareSignupPage.tsx +267 -0
- package/src/components/auth/TraditionalAuthSection.tsx +99 -0
- package/src/components/recovery/CompleteStep.tsx +36 -0
- package/src/components/recovery/InitiateRecoveryStep.tsx +68 -0
- package/src/components/recovery/SelectMethodStep.tsx +73 -0
- package/src/components/recovery/SetPasswordStep.tsx +97 -0
- package/src/components/recovery/VerifyCodeStep.tsx +90 -0
- package/src/components/reserved/ReservedRecoveryWarning.tsx +160 -0
- package/src/components/reserved/ReservedStatusBox.tsx +118 -0
- package/src/components/ui/BetaBadge.tsx +58 -0
- package/src/components/ui/Footer.tsx +93 -0
- package/src/config/env.ts +57 -0
- package/src/config/logger.ts +62 -0
- package/src/config/logging-config.ts +82 -0
- package/src/config/unauthenticated-routes.ts +19 -0
- package/src/config/vibe-log-transport.ts +250 -0
- package/src/edge/internal-api-url.ts +65 -0
- package/src/edge/middleware.ts +42 -0
- package/src/hooks/useAuth.ts +115 -0
- package/src/hooks/useAuthSettings.ts +97 -0
- package/src/hooks/useAvailableProviders.ts +118 -0
- package/src/hooks/usePasswordValidation.ts +127 -0
- package/src/hooks/useProfile.ts +75 -0
- package/src/hooks/usePublicAuthSettings.ts +149 -0
- package/src/hooks/useSessionExpiration.ts +102 -0
- package/src/hooks/useViabilitySession.ts +335 -0
- package/src/index.ts +63 -0
- package/src/lib/anon-session.ts +213 -0
- package/src/lib/api-handler.ts +625 -0
- package/src/lib/app-slug.ts +178 -0
- package/src/lib/demo-mode.ts +13 -0
- package/src/lib/geolocation.ts +265 -0
- package/src/lib/idp-client-config.ts +442 -0
- package/src/lib/idp-fetch.ts +101 -0
- package/src/lib/internal-api.ts +171 -0
- package/src/lib/jwt-decode-client.ts +45 -0
- package/src/lib/jwt-decode.ts +83 -0
- package/src/lib/nextauth-secret.ts +126 -0
- package/src/lib/rate-limit-service.ts +9 -0
- package/src/lib/redis.ts +27 -0
- package/src/lib/refresh-token-validator.ts +64 -0
- package/src/lib/roles.ts +177 -0
- package/src/lib/secret-validation.ts +8 -0
- package/src/lib/session-store.ts +637 -0
- package/src/lib/session.ts +34 -0
- package/src/lib/site-logger.ts +245 -0
- package/src/lib/standardized-client-api.ts +896 -0
- package/src/lib/startup-init.ts +247 -0
- package/src/lib/test-aware-get-token.ts +30 -0
- package/src/lib/token-expiry.ts +40 -0
- package/src/lib/token-lifecycle.ts +477 -0
- package/src/lib/types/api-responses.ts +336 -0
- package/src/lib/user-agent-parser.ts +252 -0
- package/src/logging/api/admin-analytics.ts +51 -0
- package/src/logging/api/audit-log.ts +53 -0
- package/src/logging/components/AdminAnalyticsLayout.tsx +49 -0
- package/src/logging/components/AuditLogViewer.tsx +125 -0
- package/src/logging/components/ErrorMetricsCard.tsx +98 -0
- package/src/logging/components/HealthMetricsCard.tsx +70 -0
- package/src/logging/hooks/useAdminAnalytics.ts +22 -0
- package/src/logging/hooks/useAuditLog.ts +24 -0
- package/src/logging/hooks/useErrorMetrics.ts +40 -0
- package/src/logging/hooks/useHealthMetrics.ts +44 -0
- package/src/logging/index.ts +18 -0
- package/src/logging/types/analytics.ts +81 -0
- package/src/logging/types/audit.ts +31 -0
- package/src/logging/types/index.ts +3 -0
- package/src/middleware/auth-decision.ts +43 -0
- package/src/middleware/create-middleware.ts +626 -0
- package/src/middleware/rbac-check.ts +244 -0
- package/src/middleware/twofa-presets.ts +224 -0
- package/src/models/DecodedAccessToken.ts +17 -0
- package/src/models/SessionModel.ts +258 -0
- package/src/pages/admin-login/page.tsx +229 -0
- package/src/pages/admin-roles/RolesAdminPage.tsx +357 -0
- package/src/pages/admin-roles/index.ts +9 -0
- package/src/pages/admin-roles/modals.tsx +469 -0
- package/src/pages/client-admin/ClientSiteAdminPage.tsx +380 -0
- package/src/pages/client-admin/index.ts +33 -0
- package/src/pages/login/page.tsx +463 -0
- package/src/pages/profile/EnhancedProfilePage.tsx +479 -0
- package/src/pages/profile/index.ts +9 -0
- package/src/pages/profile/page.tsx +166 -0
- package/src/pages/recovery/page.tsx +234 -0
- package/src/pages/roles/MyRolesPage.tsx +211 -0
- package/src/pages/roles/components.tsx +294 -0
- package/src/pages/roles/index.ts +17 -0
- package/src/pages/security/EnhancedSecurityPage.tsx +574 -0
- package/src/pages/security/index.ts +9 -0
- package/src/pages/security/page.tsx +507 -0
- package/src/pages/settings/EnhancedSettingsPage.tsx +642 -0
- package/src/pages/settings/index.ts +9 -0
- package/src/pages/settings/page.tsx +47 -0
- package/src/pages/showcase/ShowcasePage.tsx +530 -0
- package/src/pages/showcase/index.ts +13 -0
- package/src/pages/test-env/EmergencyLogoutPage.tsx +179 -0
- package/src/pages/test-env/JwtInspectPage.tsx +418 -0
- package/src/pages/test-env/RefreshTokenPage.tsx +155 -0
- package/src/pages/test-env/TestEnvPage.tsx +116 -0
- package/src/pages/test-env/index.ts +25 -0
- package/src/pages/verify-code/page.tsx +648 -0
- package/src/routes/account/index.ts +32 -0
- package/src/routes/account/masked-info.ts +37 -0
- package/src/routes/account/send-code.ts +40 -0
- package/src/routes/account/update-phone.ts +13 -0
- package/src/routes/account/verify-email.ts +41 -0
- package/src/routes/account/verify-sms.ts +41 -0
- package/src/routes/auth/index.ts +23 -0
- package/src/routes/auth/logout.ts +127 -0
- package/src/routes/auth/nextauth.ts +71 -0
- package/src/routes/auth/refresh.ts +54 -0
- package/src/routes/auth/session.ts +193 -0
- package/src/routes/auth/settings.ts +75 -0
- package/src/routes/auth/viability.ts +220 -0
- package/src/routes/index.ts +18 -0
- package/src/routes/session/index.ts +7 -0
- package/src/routes/session/refresh-viability.ts +17 -0
- package/src/services/signalrActivityService.ts +258 -0
- package/src/stores/authStore.ts +1904 -0
- package/src/templates/instrumentation.ts +41 -0
- package/src/theme/ThemeProvider.tsx +39 -0
- package/src/theme/default.ts +33 -0
- package/src/theme/index.ts +31 -0
- package/src/theme/types.ts +69 -0
- package/src/theme/useTheme.ts +57 -0
- package/src/theme/utils.ts +40 -0
- package/src/types/api.ts +13 -0
- package/src/types/auth.d.ts +15 -0
- package/src/types/auth.ts +22 -0
- package/src/types/logging.ts +11 -0
- package/src/types/next-auth.d.ts +15 -0
- package/src/types/recovery.ts +54 -0
- package/src/types/security.ts +1 -0
- package/src/utils/api.ts +353 -0
- package/src/utils/circuitBreaker.ts +40 -0
- package/src/utils/error-message.ts +108 -0
- package/src/utils/layout/reservedSpace.ts +124 -0
- package/src/utils/logout.ts +30 -0
- package/src/vibe/client.ts +590 -0
- package/src/vibe/errors.ts +185 -0
- package/src/vibe/generic.ts +429 -0
- package/src/vibe/hooks/index.ts +367 -0
- package/src/vibe/index.ts +121 -0
- package/src/vibe/sessions.ts +551 -0
- package/src/vibe/types.ts +577 -0
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Ready-to-Use NextAuth Route Handler
|
|
4
|
+
*
|
|
5
|
+
* Provides a pre-configured NextAuth handler that uses dynamic OAuth providers
|
|
6
|
+
* loaded from IDP at startup via getAuthOptions().
|
|
7
|
+
*
|
|
8
|
+
* @version 2.2.0 - Dynamic provider loading from IDP
|
|
9
|
+
* @since auth-ready-v2-hotfix
|
|
10
|
+
*/
|
|
11
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.GET = GET;
|
|
16
|
+
exports.POST = POST;
|
|
17
|
+
const next_auth_1 = __importDefault(require("next-auth"));
|
|
18
|
+
const auth_options_1 = require("../../auth/auth-options");
|
|
19
|
+
// Cached handler - built once with dynamic providers
|
|
20
|
+
let cachedHandler = null;
|
|
21
|
+
let handlerPromise = null;
|
|
22
|
+
/**
|
|
23
|
+
* Get or build the NextAuth handler with dynamic providers.
|
|
24
|
+
* Uses caching to avoid rebuilding on every request.
|
|
25
|
+
*/
|
|
26
|
+
async function getHandler() {
|
|
27
|
+
// Return cached if available
|
|
28
|
+
if (cachedHandler) {
|
|
29
|
+
return cachedHandler;
|
|
30
|
+
}
|
|
31
|
+
// Prevent concurrent builds
|
|
32
|
+
if (handlerPromise) {
|
|
33
|
+
return handlerPromise;
|
|
34
|
+
}
|
|
35
|
+
handlerPromise = (async () => {
|
|
36
|
+
try {
|
|
37
|
+
// Try to get dynamic auth options from IDP
|
|
38
|
+
const options = await (0, auth_options_1.getAuthOptions)();
|
|
39
|
+
console.log('[NEXTAUTH_ROUTE] Built handler with dynamic providers');
|
|
40
|
+
cachedHandler = (0, next_auth_1.default)(options);
|
|
41
|
+
return cachedHandler;
|
|
42
|
+
}
|
|
43
|
+
catch (error) {
|
|
44
|
+
// Fallback to static options if IDP unavailable
|
|
45
|
+
console.warn('[NEXTAUTH_ROUTE] Failed to get dynamic options, using static fallback:', {
|
|
46
|
+
error: error instanceof Error ? error.message : String(error)
|
|
47
|
+
});
|
|
48
|
+
cachedHandler = (0, next_auth_1.default)(auth_options_1.authOptions);
|
|
49
|
+
return cachedHandler;
|
|
50
|
+
}
|
|
51
|
+
finally {
|
|
52
|
+
handlerPromise = null;
|
|
53
|
+
}
|
|
54
|
+
})();
|
|
55
|
+
return handlerPromise;
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* GET handler for NextAuth
|
|
59
|
+
* Uses async factory to get dynamic providers from IDP
|
|
60
|
+
*/
|
|
61
|
+
async function GET(request, context) {
|
|
62
|
+
const handler = await getHandler();
|
|
63
|
+
return handler(request, context);
|
|
64
|
+
}
|
|
65
|
+
/**
|
|
66
|
+
* POST handler for NextAuth
|
|
67
|
+
* Uses async factory to get dynamic providers from IDP
|
|
68
|
+
*/
|
|
69
|
+
async function POST(request, context) {
|
|
70
|
+
const handler = await getHandler();
|
|
71
|
+
return handler(request, context);
|
|
72
|
+
}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Ready-to-Use Refresh Token Route
|
|
3
|
+
*
|
|
4
|
+
* Provides a pre-configured refresh handler that can be imported directly
|
|
5
|
+
* into your app's API routes with zero configuration.
|
|
6
|
+
*
|
|
7
|
+
* @example
|
|
8
|
+
* ```typescript
|
|
9
|
+
* // app/api/auth/refresh/route.ts
|
|
10
|
+
* export { POST } from '@payez/next-mvp/routes/auth/refresh';
|
|
11
|
+
* ```
|
|
12
|
+
*
|
|
13
|
+
* @version 2.0.0
|
|
14
|
+
* @since auth-ready-v2
|
|
15
|
+
*/
|
|
16
|
+
import { NextRequest } from 'next/server';
|
|
17
|
+
export declare function POST(req: NextRequest): Promise<import("next/server").NextResponse<{
|
|
18
|
+
error: string;
|
|
19
|
+
code: string;
|
|
20
|
+
}> | import("next/server").NextResponse<{
|
|
21
|
+
error: any;
|
|
22
|
+
code: any;
|
|
23
|
+
discardToken: boolean;
|
|
24
|
+
retryable: boolean;
|
|
25
|
+
resolution: any;
|
|
26
|
+
}> | import("next/server").NextResponse<{
|
|
27
|
+
refreshed: boolean;
|
|
28
|
+
accessTokenExpires: number;
|
|
29
|
+
hasRefreshToken: boolean;
|
|
30
|
+
}>>;
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Ready-to-Use Refresh Token Route
|
|
4
|
+
*
|
|
5
|
+
* Provides a pre-configured refresh handler that can be imported directly
|
|
6
|
+
* into your app's API routes with zero configuration.
|
|
7
|
+
*
|
|
8
|
+
* @example
|
|
9
|
+
* ```typescript
|
|
10
|
+
* // app/api/auth/refresh/route.ts
|
|
11
|
+
* export { POST } from '@payez/next-mvp/routes/auth/refresh';
|
|
12
|
+
* ```
|
|
13
|
+
*
|
|
14
|
+
* @version 2.0.0
|
|
15
|
+
* @since auth-ready-v2
|
|
16
|
+
*/
|
|
17
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
+
exports.POST = POST;
|
|
19
|
+
const refresh_1 = require("../../api-handlers/auth/refresh");
|
|
20
|
+
const idp_client_config_1 = require("../../lib/idp-client-config");
|
|
21
|
+
// Configuration is read at runtime from IDP config (cached)
|
|
22
|
+
async function getConfig() {
|
|
23
|
+
const idpConfig = await (0, idp_client_config_1.getIDPClientConfig)();
|
|
24
|
+
const idpBaseUrl = process.env.IDP_URL;
|
|
25
|
+
if (!idpBaseUrl) {
|
|
26
|
+
throw new Error('[IDP_URL] FATAL: IDP_URL environment variable is REQUIRED.');
|
|
27
|
+
}
|
|
28
|
+
return {
|
|
29
|
+
idpBaseUrl,
|
|
30
|
+
clientId: process.env.CLIENT_ID || process.env.NEXT_PUBLIC_IDP_CLIENT_ID || '',
|
|
31
|
+
nextAuthSecret: idpConfig.nextAuthSecret || '',
|
|
32
|
+
refreshEndpoint: process.env.REFRESH_ENDPOINT || '/api/ExternalAuth/refresh',
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Pre-configured POST handler for token refresh
|
|
37
|
+
*
|
|
38
|
+
* Environment variables used:
|
|
39
|
+
* - IDP_URL (REQUIRED)
|
|
40
|
+
* - CLIENT_ID or NEXT_PUBLIC_IDP_CLIENT_ID (required)
|
|
41
|
+
* - NEXTAUTH_SECRET (required)
|
|
42
|
+
* - REFRESH_ENDPOINT (default: /api/ExternalAuth/refresh)
|
|
43
|
+
*/
|
|
44
|
+
let _handler = null;
|
|
45
|
+
async function POST(req) {
|
|
46
|
+
if (!_handler) {
|
|
47
|
+
const config = await getConfig();
|
|
48
|
+
_handler = (0, refresh_1.createRefreshHandler)(config);
|
|
49
|
+
}
|
|
50
|
+
return _handler(req);
|
|
51
|
+
}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Ready-to-Use Session Management Route
|
|
3
|
+
*
|
|
4
|
+
* Provides pre-configured session handlers for checking and updating session state.
|
|
5
|
+
*
|
|
6
|
+
* @example
|
|
7
|
+
* ```typescript
|
|
8
|
+
* // app/api/auth/session/route.ts
|
|
9
|
+
* export { GET, POST } from '@payez/next-mvp/routes/auth/session';
|
|
10
|
+
* ```
|
|
11
|
+
*
|
|
12
|
+
* @version 2.0.0
|
|
13
|
+
* @since auth-ready-v2
|
|
14
|
+
*/
|
|
15
|
+
import { NextRequest, NextResponse } from 'next/server';
|
|
16
|
+
/**
|
|
17
|
+
* GET /api/auth/session - Check current session status
|
|
18
|
+
*
|
|
19
|
+
* Returns the current session information including:
|
|
20
|
+
* - User details
|
|
21
|
+
* - Token expiry status
|
|
22
|
+
* - Session validity
|
|
23
|
+
*/
|
|
24
|
+
export declare function GET(req: NextRequest): Promise<NextResponse<{
|
|
25
|
+
authenticated: boolean;
|
|
26
|
+
message: string;
|
|
27
|
+
}> | NextResponse<{
|
|
28
|
+
user: {
|
|
29
|
+
id: string | undefined;
|
|
30
|
+
email: string | null | undefined;
|
|
31
|
+
name: string | null | undefined;
|
|
32
|
+
image: any;
|
|
33
|
+
roles: string[];
|
|
34
|
+
twoFactorSessionVerified: boolean;
|
|
35
|
+
requiresTwoFactor: boolean;
|
|
36
|
+
authenticationMethods: string[] | undefined;
|
|
37
|
+
authenticationLevel: string | undefined;
|
|
38
|
+
mfaCompletedAt: number | undefined;
|
|
39
|
+
mfaExpiresAt: number | undefined;
|
|
40
|
+
mfaValidityHours: number | undefined;
|
|
41
|
+
oauthProvider: string | undefined;
|
|
42
|
+
idpClientId: string | undefined;
|
|
43
|
+
merchantId: string | undefined;
|
|
44
|
+
};
|
|
45
|
+
sessionToken: any;
|
|
46
|
+
accessToken: string | undefined;
|
|
47
|
+
refreshToken: string | undefined;
|
|
48
|
+
accessTokenExpires: number | undefined;
|
|
49
|
+
expires: string;
|
|
50
|
+
}> | NextResponse<{
|
|
51
|
+
error: string;
|
|
52
|
+
details: string;
|
|
53
|
+
}>>;
|
|
54
|
+
/**
|
|
55
|
+
* POST /api/auth/session - Update session data
|
|
56
|
+
*
|
|
57
|
+
* Allows updating session metadata (not tokens).
|
|
58
|
+
* Token refresh should use the /api/auth/refresh endpoint.
|
|
59
|
+
*
|
|
60
|
+
* Body:
|
|
61
|
+
* - metadata: object - Custom metadata to store in session
|
|
62
|
+
*/
|
|
63
|
+
export declare function POST(req: NextRequest): Promise<NextResponse<{
|
|
64
|
+
error: string;
|
|
65
|
+
code: string;
|
|
66
|
+
}> | NextResponse<{
|
|
67
|
+
success: boolean;
|
|
68
|
+
message: string;
|
|
69
|
+
}> | NextResponse<{
|
|
70
|
+
error: string;
|
|
71
|
+
details: string;
|
|
72
|
+
}>>;
|
|
@@ -0,0 +1,180 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Ready-to-Use Session Management Route
|
|
4
|
+
*
|
|
5
|
+
* Provides pre-configured session handlers for checking and updating session state.
|
|
6
|
+
*
|
|
7
|
+
* @example
|
|
8
|
+
* ```typescript
|
|
9
|
+
* // app/api/auth/session/route.ts
|
|
10
|
+
* export { GET, POST } from '@payez/next-mvp/routes/auth/session';
|
|
11
|
+
* ```
|
|
12
|
+
*
|
|
13
|
+
* @version 2.0.0
|
|
14
|
+
* @since auth-ready-v2
|
|
15
|
+
*/
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
exports.GET = GET;
|
|
18
|
+
exports.POST = POST;
|
|
19
|
+
const server_1 = require("next/server");
|
|
20
|
+
const jwt_1 = require("next-auth/jwt");
|
|
21
|
+
const session_store_1 = require("../../lib/session-store");
|
|
22
|
+
const app_slug_1 = require("../../lib/app-slug");
|
|
23
|
+
const idp_client_config_1 = require("../../lib/idp-client-config");
|
|
24
|
+
/**
|
|
25
|
+
* Get NextAuth secret from IDP config (cached).
|
|
26
|
+
* NEVER use process.env.NEXTAUTH_SECRET - it's always loaded from IDP.
|
|
27
|
+
*/
|
|
28
|
+
async function getNextAuthSecret() {
|
|
29
|
+
const config = await (0, idp_client_config_1.getIDPClientConfig)();
|
|
30
|
+
return config.nextAuthSecret || '';
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* GET /api/auth/session - Check current session status
|
|
34
|
+
*
|
|
35
|
+
* Returns the current session information including:
|
|
36
|
+
* - User details
|
|
37
|
+
* - Token expiry status
|
|
38
|
+
* - Session validity
|
|
39
|
+
*/
|
|
40
|
+
async function GET(req) {
|
|
41
|
+
try {
|
|
42
|
+
const secret = await getNextAuthSecret();
|
|
43
|
+
const cookieName = (0, app_slug_1.getJwtCookieName)();
|
|
44
|
+
// Debug logging
|
|
45
|
+
const cookieValue = req.cookies.get(cookieName)?.value;
|
|
46
|
+
console.log('[SESSION_ROUTE] GET called:', {
|
|
47
|
+
cookieName,
|
|
48
|
+
hasCookie: !!cookieValue,
|
|
49
|
+
cookieLength: cookieValue?.length || 0,
|
|
50
|
+
secretLength: secret?.length || 0,
|
|
51
|
+
});
|
|
52
|
+
const token = await (0, jwt_1.getToken)({ req, secret, cookieName });
|
|
53
|
+
if (!token) {
|
|
54
|
+
console.warn('[SESSION_ROUTE] getToken returned null');
|
|
55
|
+
return server_1.NextResponse.json({
|
|
56
|
+
authenticated: false,
|
|
57
|
+
message: 'No session found'
|
|
58
|
+
}, { status: 200 });
|
|
59
|
+
}
|
|
60
|
+
// Support both field names: sessionToken (auth.ts JWT) and redisSessionId (legacy)
|
|
61
|
+
const redisSessionId = token.sessionToken || token.redisSessionId;
|
|
62
|
+
console.log('[SESSION_ROUTE] Token found:', {
|
|
63
|
+
sub: token.sub,
|
|
64
|
+
email: token.email,
|
|
65
|
+
name: token.name,
|
|
66
|
+
hasExp: !!token.exp,
|
|
67
|
+
redisSessionId: redisSessionId ? redisSessionId.substring(0, 8) + '...' : 'MISSING',
|
|
68
|
+
});
|
|
69
|
+
// Fetch full session data from Redis
|
|
70
|
+
const session = redisSessionId ? await (0, session_store_1.getSession)(redisSessionId) : null;
|
|
71
|
+
console.log('[SESSION_ROUTE] Redis session:', {
|
|
72
|
+
found: !!session,
|
|
73
|
+
userId: session?.userId,
|
|
74
|
+
roles: session?.roles,
|
|
75
|
+
hasAccessToken: !!session?.idpAccessToken,
|
|
76
|
+
});
|
|
77
|
+
// Return NextAuth-compatible session format with Redis data
|
|
78
|
+
// useSession() expects: { user: {...}, expires: "..." }
|
|
79
|
+
// We enrich with all session data from Redis
|
|
80
|
+
return server_1.NextResponse.json({
|
|
81
|
+
user: {
|
|
82
|
+
id: session?.userId || token.sub,
|
|
83
|
+
email: session?.email || token.email,
|
|
84
|
+
name: session?.name || token.name,
|
|
85
|
+
image: token.picture || null,
|
|
86
|
+
// Redis session data
|
|
87
|
+
roles: session?.roles || [],
|
|
88
|
+
twoFactorSessionVerified: session?.mfaVerified || false,
|
|
89
|
+
requiresTwoFactor: !session?.mfaVerified,
|
|
90
|
+
authenticationMethods: session?.authenticationMethods,
|
|
91
|
+
authenticationLevel: session?.authenticationLevel,
|
|
92
|
+
mfaCompletedAt: session?.mfaCompletedAt,
|
|
93
|
+
mfaExpiresAt: session?.mfaExpiresAt,
|
|
94
|
+
mfaValidityHours: session?.mfaValidityHours,
|
|
95
|
+
oauthProvider: session?.oauthProvider,
|
|
96
|
+
idpClientId: session?.idpClientId,
|
|
97
|
+
merchantId: session?.merchantId,
|
|
98
|
+
},
|
|
99
|
+
// Session tokens
|
|
100
|
+
sessionToken: redisSessionId,
|
|
101
|
+
accessToken: session?.idpAccessToken,
|
|
102
|
+
refreshToken: session?.idpRefreshToken,
|
|
103
|
+
accessTokenExpires: session?.idpAccessTokenExpires,
|
|
104
|
+
expires: token.exp ? new Date(token.exp * 1000).toISOString() : new Date(Date.now() + 30 * 24 * 60 * 60 * 1000).toISOString(),
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
catch (error) {
|
|
108
|
+
console.error('[SESSION_ROUTE] Error checking session:', error);
|
|
109
|
+
return server_1.NextResponse.json({
|
|
110
|
+
error: 'Failed to check session',
|
|
111
|
+
details: error instanceof Error ? error.message : 'Unknown error'
|
|
112
|
+
}, { status: 500 });
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
/**
|
|
116
|
+
* POST /api/auth/session - Update session data
|
|
117
|
+
*
|
|
118
|
+
* Allows updating session metadata (not tokens).
|
|
119
|
+
* Token refresh should use the /api/auth/refresh endpoint.
|
|
120
|
+
*
|
|
121
|
+
* Body:
|
|
122
|
+
* - metadata: object - Custom metadata to store in session
|
|
123
|
+
*/
|
|
124
|
+
async function POST(req) {
|
|
125
|
+
try {
|
|
126
|
+
const secret = await getNextAuthSecret();
|
|
127
|
+
const token = await (0, jwt_1.getToken)({ req, secret, cookieName: (0, app_slug_1.getJwtCookieName)() });
|
|
128
|
+
if (!token) {
|
|
129
|
+
return server_1.NextResponse.json({
|
|
130
|
+
error: 'No session found',
|
|
131
|
+
code: 'UNAUTHORIZED'
|
|
132
|
+
}, { status: 401 });
|
|
133
|
+
}
|
|
134
|
+
// Support both field names: sessionToken (auth.ts JWT) and redisSessionId (legacy)
|
|
135
|
+
const sessionToken = token.sessionToken || token.redisSessionId;
|
|
136
|
+
if (!sessionToken) {
|
|
137
|
+
return server_1.NextResponse.json({
|
|
138
|
+
error: 'Invalid session',
|
|
139
|
+
code: 'INVALID_SESSION'
|
|
140
|
+
}, { status: 400 });
|
|
141
|
+
}
|
|
142
|
+
const body = await req.json();
|
|
143
|
+
const { metadata, access_token, refresh_token, twoFactorComplete, twoFactorMethod } = body;
|
|
144
|
+
// Get current session
|
|
145
|
+
const session = await (0, session_store_1.getSession)(sessionToken);
|
|
146
|
+
if (!session) {
|
|
147
|
+
return server_1.NextResponse.json({
|
|
148
|
+
error: 'Session not found',
|
|
149
|
+
code: 'SESSION_NOT_FOUND'
|
|
150
|
+
}, { status: 404 });
|
|
151
|
+
}
|
|
152
|
+
// Update session with new data
|
|
153
|
+
const updatedSession = {
|
|
154
|
+
...session,
|
|
155
|
+
...(access_token ? { accessToken: access_token } : {}),
|
|
156
|
+
...(refresh_token ? { refreshToken: refresh_token } : {}),
|
|
157
|
+
...(typeof twoFactorComplete === 'boolean' ? { twoFactorComplete } : {}),
|
|
158
|
+
...(twoFactorMethod ? { twoFactorMethod } : {}),
|
|
159
|
+
...(metadata ? {
|
|
160
|
+
metadata: {
|
|
161
|
+
...(session.metadata || {}),
|
|
162
|
+
...metadata,
|
|
163
|
+
updatedAt: new Date().toISOString()
|
|
164
|
+
}
|
|
165
|
+
} : {})
|
|
166
|
+
};
|
|
167
|
+
await (0, session_store_1.updateSession)(sessionToken, updatedSession);
|
|
168
|
+
return server_1.NextResponse.json({
|
|
169
|
+
success: true,
|
|
170
|
+
message: 'Session updated successfully'
|
|
171
|
+
});
|
|
172
|
+
}
|
|
173
|
+
catch (error) {
|
|
174
|
+
console.error('[SESSION_ROUTE] Error updating session:', error);
|
|
175
|
+
return server_1.NextResponse.json({
|
|
176
|
+
error: 'Failed to update session',
|
|
177
|
+
details: error instanceof Error ? error.message : 'Unknown error'
|
|
178
|
+
}, { status: 500 });
|
|
179
|
+
}
|
|
180
|
+
}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Public Auth Settings Route
|
|
3
|
+
*
|
|
4
|
+
* Returns client auth settings for pre-login pages (signup, login).
|
|
5
|
+
* Does NOT require authentication - these are public client settings.
|
|
6
|
+
*/
|
|
7
|
+
import { NextResponse } from 'next/server';
|
|
8
|
+
export interface PublicAuthSettings {
|
|
9
|
+
enabledProviders: string[];
|
|
10
|
+
allowPublicRegistration: boolean;
|
|
11
|
+
allowSocialLogin: boolean;
|
|
12
|
+
enablePasswordReset: boolean;
|
|
13
|
+
require2FA: boolean;
|
|
14
|
+
allowed2FAMethods: string[];
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* GET /api/auth/settings
|
|
18
|
+
*
|
|
19
|
+
* Returns public auth settings for the current client.
|
|
20
|
+
* Used by login/signup pages to determine what options to show.
|
|
21
|
+
*/
|
|
22
|
+
export declare function GET(): Promise<NextResponse<{
|
|
23
|
+
success: boolean;
|
|
24
|
+
data: PublicAuthSettings;
|
|
25
|
+
}>>;
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Public Auth Settings Route
|
|
4
|
+
*
|
|
5
|
+
* Returns client auth settings for pre-login pages (signup, login).
|
|
6
|
+
* Does NOT require authentication - these are public client settings.
|
|
7
|
+
*/
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.GET = GET;
|
|
10
|
+
const server_1 = require("next/server");
|
|
11
|
+
const idp_client_config_1 = require("../../lib/idp-client-config");
|
|
12
|
+
/**
|
|
13
|
+
* GET /api/auth/settings
|
|
14
|
+
*
|
|
15
|
+
* Returns public auth settings for the current client.
|
|
16
|
+
* Used by login/signup pages to determine what options to show.
|
|
17
|
+
*/
|
|
18
|
+
async function GET() {
|
|
19
|
+
try {
|
|
20
|
+
const config = await (0, idp_client_config_1.getIDPClientConfig)();
|
|
21
|
+
const settings = {
|
|
22
|
+
// Get enabled OAuth provider names
|
|
23
|
+
enabledProviders: config.oauthProviders
|
|
24
|
+
?.filter(p => p.enabled)
|
|
25
|
+
.map(p => p.provider) ?? [],
|
|
26
|
+
// Registration - default to true if not specified
|
|
27
|
+
allowPublicRegistration: true, // Could come from config.authSettings in future
|
|
28
|
+
allowSocialLogin: config.oauthProviders?.some(p => p.enabled) ?? false,
|
|
29
|
+
// Password reset
|
|
30
|
+
enablePasswordReset: true, // Could come from config.authSettings in future
|
|
31
|
+
// 2FA
|
|
32
|
+
require2FA: config.authSettings?.require2FA ?? true,
|
|
33
|
+
allowed2FAMethods: config.authSettings?.allowed2FAMethods ?? ['email', 'sms'],
|
|
34
|
+
};
|
|
35
|
+
return server_1.NextResponse.json({
|
|
36
|
+
success: true,
|
|
37
|
+
data: settings,
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
catch (error) {
|
|
41
|
+
console.error('[AUTH_SETTINGS] Failed to get settings:', error);
|
|
42
|
+
// Return safe defaults on error
|
|
43
|
+
return server_1.NextResponse.json({
|
|
44
|
+
success: true,
|
|
45
|
+
data: {
|
|
46
|
+
enabledProviders: [],
|
|
47
|
+
allowPublicRegistration: true,
|
|
48
|
+
allowSocialLogin: false,
|
|
49
|
+
enablePasswordReset: true,
|
|
50
|
+
require2FA: true,
|
|
51
|
+
allowed2FAMethods: ['email', 'sms'],
|
|
52
|
+
},
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Ready-to-Use Session Viability Route
|
|
3
|
+
*
|
|
4
|
+
* Checks if the current session is viable (valid and not expired).
|
|
5
|
+
* Used by client-side code to determine if a refresh is needed.
|
|
6
|
+
*
|
|
7
|
+
* @example
|
|
8
|
+
* ```typescript
|
|
9
|
+
* // app/api/session/viability/route.ts
|
|
10
|
+
* export { GET } from '@payez/next-mvp/routes/auth/viability';
|
|
11
|
+
* ```
|
|
12
|
+
*
|
|
13
|
+
* @version 2.0.0
|
|
14
|
+
* @since auth-ready-v2
|
|
15
|
+
*/
|
|
16
|
+
import { NextRequest, NextResponse } from 'next/server';
|
|
17
|
+
/**
|
|
18
|
+
* GET /api/session/viability - Check if session is viable
|
|
19
|
+
*
|
|
20
|
+
* Returns:
|
|
21
|
+
* - viable: boolean - Whether the session can be used
|
|
22
|
+
* - needsRefresh: boolean - Whether a refresh is recommended
|
|
23
|
+
* - expiresIn: number - Seconds until token expires
|
|
24
|
+
*/
|
|
25
|
+
export declare function GET(req: NextRequest): Promise<NextResponse<{
|
|
26
|
+
viable: boolean;
|
|
27
|
+
needsRefresh: boolean;
|
|
28
|
+
authenticated: boolean;
|
|
29
|
+
reason: string;
|
|
30
|
+
}> | NextResponse<{
|
|
31
|
+
viable: boolean;
|
|
32
|
+
needsRefresh: boolean;
|
|
33
|
+
expiresIn: number;
|
|
34
|
+
hasRefreshToken: boolean;
|
|
35
|
+
authenticated: boolean;
|
|
36
|
+
sessionToken: any;
|
|
37
|
+
tenantRequiresTwoFactor: boolean;
|
|
38
|
+
userHasCompletedTenantTwoFactorRequirements: any;
|
|
39
|
+
userStillNeedsTwoFactor: boolean;
|
|
40
|
+
requires2FA: boolean;
|
|
41
|
+
twoFactorComplete: any;
|
|
42
|
+
accessTokenExpired: boolean;
|
|
43
|
+
expiresAt: string;
|
|
44
|
+
roles: string[];
|
|
45
|
+
clientId: string;
|
|
46
|
+
}> | NextResponse<{
|
|
47
|
+
viable: boolean;
|
|
48
|
+
needsRefresh: boolean;
|
|
49
|
+
authenticated: boolean;
|
|
50
|
+
error: string;
|
|
51
|
+
details: string;
|
|
52
|
+
}>>;
|