@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,383 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* IDP Client Utilities
|
|
4
|
+
*
|
|
5
|
+
* Functions for calling PayEz IDP API endpoints.
|
|
6
|
+
* Handles login, OAuth callback, token refresh, and 2FA verification.
|
|
7
|
+
*
|
|
8
|
+
* URL USAGE:
|
|
9
|
+
* - IDP_URL: Used for all calls to the PayEz Identity Provider
|
|
10
|
+
* - INTERNAL_API_URL: NOT used here - that's for calling THIS app's own endpoints
|
|
11
|
+
*
|
|
12
|
+
* @version 1.0.0
|
|
13
|
+
* @since auth-refactor-2026-01
|
|
14
|
+
*/
|
|
15
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
16
|
+
exports.getIdpUrl = getIdpUrl;
|
|
17
|
+
exports.getClientId = getClientId;
|
|
18
|
+
exports.idpLogin = idpLogin;
|
|
19
|
+
exports.idpOAuthCallback = idpOAuthCallback;
|
|
20
|
+
exports.idpRefreshToken = idpRefreshToken;
|
|
21
|
+
exports.idpVerify2FA = idpVerify2FA;
|
|
22
|
+
exports.idpSend2FACode = idpSend2FACode;
|
|
23
|
+
// ============================================================================
|
|
24
|
+
// CONFIGURATION
|
|
25
|
+
// ============================================================================
|
|
26
|
+
/**
|
|
27
|
+
* Get IDP base URL. Throws if not configured.
|
|
28
|
+
*/
|
|
29
|
+
function getIdpUrl() {
|
|
30
|
+
const url = process.env.IDP_URL;
|
|
31
|
+
if (!url) {
|
|
32
|
+
throw new Error('[IDP_CLIENT] FATAL: IDP_URL environment variable is REQUIRED');
|
|
33
|
+
}
|
|
34
|
+
return url.replace(/\/$/, ''); // Remove trailing slash
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* Get client ID for this application.
|
|
38
|
+
*/
|
|
39
|
+
function getClientId() {
|
|
40
|
+
const clientId = process.env.CLIENT_ID || process.env.NEXT_PUBLIC_CLIENT_ID;
|
|
41
|
+
if (!clientId) {
|
|
42
|
+
throw new Error('[IDP_CLIENT] FATAL: CLIENT_ID environment variable is REQUIRED');
|
|
43
|
+
}
|
|
44
|
+
return clientId;
|
|
45
|
+
}
|
|
46
|
+
// ============================================================================
|
|
47
|
+
// LOGIN
|
|
48
|
+
// ============================================================================
|
|
49
|
+
/**
|
|
50
|
+
* Authenticate user with email/password via IDP.
|
|
51
|
+
*
|
|
52
|
+
* @param credentials - User's email and password
|
|
53
|
+
* @param clientHeaders - Headers to forward (IP, User-Agent for audit)
|
|
54
|
+
* @returns IDP login response with tokens or error
|
|
55
|
+
*/
|
|
56
|
+
async function idpLogin(credentials, clientHeaders) {
|
|
57
|
+
const idpUrl = getIdpUrl();
|
|
58
|
+
const clientId = getClientId();
|
|
59
|
+
const headers = {
|
|
60
|
+
'Content-Type': 'application/json',
|
|
61
|
+
'X-Client-Id': clientId,
|
|
62
|
+
};
|
|
63
|
+
// Forward client IP for audit logging
|
|
64
|
+
if (clientHeaders?.ip) {
|
|
65
|
+
headers['X-Forwarded-For'] = clientHeaders.ip;
|
|
66
|
+
}
|
|
67
|
+
// Forward User-Agent for audit logging
|
|
68
|
+
if (clientHeaders?.userAgent) {
|
|
69
|
+
headers['User-Agent'] = clientHeaders.userAgent;
|
|
70
|
+
}
|
|
71
|
+
try {
|
|
72
|
+
const response = await fetch(`${idpUrl}/api/ExternalAuth/login`, {
|
|
73
|
+
method: 'POST',
|
|
74
|
+
headers,
|
|
75
|
+
body: JSON.stringify({
|
|
76
|
+
username_or_email: credentials.email,
|
|
77
|
+
password: credentials.password,
|
|
78
|
+
client_id: clientId,
|
|
79
|
+
}),
|
|
80
|
+
});
|
|
81
|
+
const data = await response.json();
|
|
82
|
+
// Unwrap PayEz response envelope if present
|
|
83
|
+
const responseData = data.data || data;
|
|
84
|
+
if (!response.ok || !responseData.result || !responseData.success) {
|
|
85
|
+
return {
|
|
86
|
+
success: false,
|
|
87
|
+
error: responseData.error || {
|
|
88
|
+
code: `HTTP_${response.status}`,
|
|
89
|
+
message: getLoginErrorMessage(response.status, responseData),
|
|
90
|
+
},
|
|
91
|
+
};
|
|
92
|
+
}
|
|
93
|
+
return {
|
|
94
|
+
success: true,
|
|
95
|
+
result: responseData.result,
|
|
96
|
+
};
|
|
97
|
+
}
|
|
98
|
+
catch (error) {
|
|
99
|
+
console.error('[IDP_CLIENT] Login request failed:', error);
|
|
100
|
+
return {
|
|
101
|
+
success: false,
|
|
102
|
+
error: {
|
|
103
|
+
code: 'NETWORK_ERROR',
|
|
104
|
+
message: 'Failed to connect to authentication service',
|
|
105
|
+
},
|
|
106
|
+
};
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
/**
|
|
110
|
+
* Get user-friendly error message for login failures.
|
|
111
|
+
*/
|
|
112
|
+
function getLoginErrorMessage(status, responseData) {
|
|
113
|
+
// Check for structured error from IDP
|
|
114
|
+
if (responseData?.error?.message) {
|
|
115
|
+
return responseData.error.message;
|
|
116
|
+
}
|
|
117
|
+
// Fallback to HTTP status-based messages
|
|
118
|
+
switch (status) {
|
|
119
|
+
case 401:
|
|
120
|
+
return 'Invalid email or password. Please try again.';
|
|
121
|
+
case 403:
|
|
122
|
+
return 'Account access denied. Please contact support.';
|
|
123
|
+
case 429:
|
|
124
|
+
return 'Too many login attempts. Please try again later.';
|
|
125
|
+
default:
|
|
126
|
+
if (status >= 500) {
|
|
127
|
+
return 'Authentication service is temporarily unavailable.';
|
|
128
|
+
}
|
|
129
|
+
return 'Authentication failed. Please try again.';
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
// ============================================================================
|
|
133
|
+
// OAUTH CALLBACK
|
|
134
|
+
// ============================================================================
|
|
135
|
+
/**
|
|
136
|
+
* Register/authenticate OAuth user with IDP.
|
|
137
|
+
*
|
|
138
|
+
* Called after OAuth provider (Google, etc.) redirects back.
|
|
139
|
+
* Creates or retrieves IDP user and returns IDP tokens.
|
|
140
|
+
*
|
|
141
|
+
* @param oauthData - Data from OAuth provider
|
|
142
|
+
* @returns IDP response with tokens and user info
|
|
143
|
+
*/
|
|
144
|
+
async function idpOAuthCallback(oauthData) {
|
|
145
|
+
const idpUrl = getIdpUrl();
|
|
146
|
+
const clientId = getClientId();
|
|
147
|
+
try {
|
|
148
|
+
const response = await fetch(`${idpUrl}/api/ExternalAuth/oauth-callback`, {
|
|
149
|
+
method: 'POST',
|
|
150
|
+
headers: {
|
|
151
|
+
'Content-Type': 'application/json',
|
|
152
|
+
'X-Client-Id': clientId,
|
|
153
|
+
},
|
|
154
|
+
body: JSON.stringify({
|
|
155
|
+
provider: oauthData.provider,
|
|
156
|
+
provider_account_id: oauthData.providerAccountId,
|
|
157
|
+
email: oauthData.email,
|
|
158
|
+
name: oauthData.name || '',
|
|
159
|
+
image: oauthData.image || '',
|
|
160
|
+
access_token: oauthData.accessToken || '',
|
|
161
|
+
refresh_token: oauthData.refreshToken || '',
|
|
162
|
+
expires_at: oauthData.expiresAt || 0,
|
|
163
|
+
}),
|
|
164
|
+
});
|
|
165
|
+
if (!response.ok) {
|
|
166
|
+
const errorText = await response.text().catch(() => 'Unknown error');
|
|
167
|
+
console.error('[IDP_CLIENT] OAuth callback failed:', response.status, errorText);
|
|
168
|
+
return {
|
|
169
|
+
success: false,
|
|
170
|
+
error: {
|
|
171
|
+
code: `HTTP_${response.status}`,
|
|
172
|
+
message: 'OAuth registration failed',
|
|
173
|
+
},
|
|
174
|
+
};
|
|
175
|
+
}
|
|
176
|
+
const data = await response.json();
|
|
177
|
+
const responseData = data.data || data;
|
|
178
|
+
// Normalize snake_case to camelCase
|
|
179
|
+
return {
|
|
180
|
+
success: responseData.success !== false,
|
|
181
|
+
data: responseData.success !== false
|
|
182
|
+
? {
|
|
183
|
+
accessToken: responseData.accessToken || responseData.access_token,
|
|
184
|
+
refreshToken: responseData.refreshToken || responseData.refresh_token,
|
|
185
|
+
isNewUser: responseData.isNewUser ?? responseData.is_new_user ?? false,
|
|
186
|
+
user: responseData.user
|
|
187
|
+
? {
|
|
188
|
+
userId: responseData.user.userId || responseData.user.user_id,
|
|
189
|
+
email: responseData.user.email || responseData.user.Email,
|
|
190
|
+
fullName: responseData.user.fullName || responseData.user.full_name || responseData.user.name,
|
|
191
|
+
roles: responseData.user.roles || [],
|
|
192
|
+
}
|
|
193
|
+
: undefined,
|
|
194
|
+
}
|
|
195
|
+
: undefined,
|
|
196
|
+
error: responseData.error,
|
|
197
|
+
};
|
|
198
|
+
}
|
|
199
|
+
catch (error) {
|
|
200
|
+
console.error('[IDP_CLIENT] OAuth callback request failed:', error);
|
|
201
|
+
return {
|
|
202
|
+
success: false,
|
|
203
|
+
error: {
|
|
204
|
+
code: 'NETWORK_ERROR',
|
|
205
|
+
message: 'Failed to connect to authentication service',
|
|
206
|
+
},
|
|
207
|
+
};
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
// ============================================================================
|
|
211
|
+
// TOKEN REFRESH
|
|
212
|
+
// ============================================================================
|
|
213
|
+
/**
|
|
214
|
+
* Refresh an expired access token using the refresh token.
|
|
215
|
+
*
|
|
216
|
+
* @param refreshToken - The refresh token from previous login
|
|
217
|
+
* @param mfaContext - MFA context to preserve across refresh
|
|
218
|
+
* @returns New tokens or error
|
|
219
|
+
*/
|
|
220
|
+
async function idpRefreshToken(refreshToken, mfaContext) {
|
|
221
|
+
const idpUrl = getIdpUrl();
|
|
222
|
+
const clientId = getClientId();
|
|
223
|
+
const requestBody = {
|
|
224
|
+
refresh_token: refreshToken,
|
|
225
|
+
};
|
|
226
|
+
// Include MFA context so new token preserves authentication level
|
|
227
|
+
if (mfaContext) {
|
|
228
|
+
if (mfaContext.amr) {
|
|
229
|
+
requestBody.amr = mfaContext.amr;
|
|
230
|
+
}
|
|
231
|
+
if (mfaContext.acr) {
|
|
232
|
+
requestBody.acr = mfaContext.acr;
|
|
233
|
+
}
|
|
234
|
+
if (mfaContext.twoFactorVerified) {
|
|
235
|
+
requestBody.two_factor_verified = true;
|
|
236
|
+
}
|
|
237
|
+
if (mfaContext.twoFactorMethod) {
|
|
238
|
+
requestBody.two_factor_method = mfaContext.twoFactorMethod;
|
|
239
|
+
}
|
|
240
|
+
if (mfaContext.twoFactorCompletedAt) {
|
|
241
|
+
requestBody.two_factor_completed_at = new Date(mfaContext.twoFactorCompletedAt).toISOString();
|
|
242
|
+
}
|
|
243
|
+
}
|
|
244
|
+
try {
|
|
245
|
+
const response = await fetch(`${idpUrl}/api/ExternalAuth/refresh`, {
|
|
246
|
+
method: 'POST',
|
|
247
|
+
headers: {
|
|
248
|
+
'Content-Type': 'application/json',
|
|
249
|
+
'X-Client-Id': clientId,
|
|
250
|
+
},
|
|
251
|
+
body: JSON.stringify(requestBody),
|
|
252
|
+
});
|
|
253
|
+
if (!response.ok) {
|
|
254
|
+
const errorText = await response.text().catch(() => 'Unknown error');
|
|
255
|
+
console.error('[IDP_CLIENT] Token refresh failed:', response.status, errorText);
|
|
256
|
+
return {
|
|
257
|
+
success: false,
|
|
258
|
+
error: {
|
|
259
|
+
code: `HTTP_${response.status}`,
|
|
260
|
+
message: response.status === 401 ? 'Refresh token expired' : 'Token refresh failed',
|
|
261
|
+
},
|
|
262
|
+
};
|
|
263
|
+
}
|
|
264
|
+
const data = await response.json();
|
|
265
|
+
if (data.success === false) {
|
|
266
|
+
return {
|
|
267
|
+
success: false,
|
|
268
|
+
error: data.error || { code: 'REFRESH_FAILED', message: 'Token refresh failed' },
|
|
269
|
+
};
|
|
270
|
+
}
|
|
271
|
+
const tokenData = data.data || data;
|
|
272
|
+
return {
|
|
273
|
+
success: true,
|
|
274
|
+
data: {
|
|
275
|
+
access_token: tokenData.access_token,
|
|
276
|
+
refresh_token: tokenData.refresh_token,
|
|
277
|
+
expires_in: tokenData.expires_in || 3600,
|
|
278
|
+
},
|
|
279
|
+
};
|
|
280
|
+
}
|
|
281
|
+
catch (error) {
|
|
282
|
+
console.error('[IDP_CLIENT] Token refresh request failed:', error);
|
|
283
|
+
return {
|
|
284
|
+
success: false,
|
|
285
|
+
error: {
|
|
286
|
+
code: 'NETWORK_ERROR',
|
|
287
|
+
message: 'Failed to connect to authentication service',
|
|
288
|
+
},
|
|
289
|
+
};
|
|
290
|
+
}
|
|
291
|
+
}
|
|
292
|
+
// ============================================================================
|
|
293
|
+
// 2FA VERIFICATION
|
|
294
|
+
// ============================================================================
|
|
295
|
+
/**
|
|
296
|
+
* Verify 2FA code with IDP.
|
|
297
|
+
*
|
|
298
|
+
* @param sessionToken - Redis session ID
|
|
299
|
+
* @param code - The 2FA code entered by user
|
|
300
|
+
* @param method - The 2FA method ('email' | 'sms' | 'totp')
|
|
301
|
+
* @returns Success status and updated tokens
|
|
302
|
+
*/
|
|
303
|
+
async function idpVerify2FA(accessToken, code, method) {
|
|
304
|
+
const idpUrl = getIdpUrl();
|
|
305
|
+
const clientId = getClientId();
|
|
306
|
+
try {
|
|
307
|
+
const response = await fetch(`${idpUrl}/api/ExternalAuth/verify-2fa`, {
|
|
308
|
+
method: 'POST',
|
|
309
|
+
headers: {
|
|
310
|
+
'Content-Type': 'application/json',
|
|
311
|
+
'X-Client-Id': clientId,
|
|
312
|
+
Authorization: `Bearer ${accessToken}`,
|
|
313
|
+
},
|
|
314
|
+
body: JSON.stringify({
|
|
315
|
+
code,
|
|
316
|
+
method,
|
|
317
|
+
}),
|
|
318
|
+
});
|
|
319
|
+
if (!response.ok) {
|
|
320
|
+
const data = await response.json().catch(() => ({}));
|
|
321
|
+
return {
|
|
322
|
+
success: false,
|
|
323
|
+
error: data.error || {
|
|
324
|
+
code: `HTTP_${response.status}`,
|
|
325
|
+
message: response.status === 401 ? 'Invalid code' : '2FA verification failed',
|
|
326
|
+
},
|
|
327
|
+
};
|
|
328
|
+
}
|
|
329
|
+
return { success: true };
|
|
330
|
+
}
|
|
331
|
+
catch (error) {
|
|
332
|
+
console.error('[IDP_CLIENT] 2FA verification failed:', error);
|
|
333
|
+
return {
|
|
334
|
+
success: false,
|
|
335
|
+
error: {
|
|
336
|
+
code: 'NETWORK_ERROR',
|
|
337
|
+
message: 'Failed to connect to authentication service',
|
|
338
|
+
},
|
|
339
|
+
};
|
|
340
|
+
}
|
|
341
|
+
}
|
|
342
|
+
/**
|
|
343
|
+
* Request a new 2FA code to be sent.
|
|
344
|
+
*
|
|
345
|
+
* @param accessToken - User's access token
|
|
346
|
+
* @param method - How to send the code ('email' | 'sms')
|
|
347
|
+
*/
|
|
348
|
+
async function idpSend2FACode(accessToken, method) {
|
|
349
|
+
const idpUrl = getIdpUrl();
|
|
350
|
+
const clientId = getClientId();
|
|
351
|
+
try {
|
|
352
|
+
const response = await fetch(`${idpUrl}/api/ExternalAuth/send-2fa-code`, {
|
|
353
|
+
method: 'POST',
|
|
354
|
+
headers: {
|
|
355
|
+
'Content-Type': 'application/json',
|
|
356
|
+
'X-Client-Id': clientId,
|
|
357
|
+
Authorization: `Bearer ${accessToken}`,
|
|
358
|
+
},
|
|
359
|
+
body: JSON.stringify({ method }),
|
|
360
|
+
});
|
|
361
|
+
if (!response.ok) {
|
|
362
|
+
const data = await response.json().catch(() => ({}));
|
|
363
|
+
return {
|
|
364
|
+
success: false,
|
|
365
|
+
error: data.error || {
|
|
366
|
+
code: `HTTP_${response.status}`,
|
|
367
|
+
message: 'Failed to send 2FA code',
|
|
368
|
+
},
|
|
369
|
+
};
|
|
370
|
+
}
|
|
371
|
+
return { success: true };
|
|
372
|
+
}
|
|
373
|
+
catch (error) {
|
|
374
|
+
console.error('[IDP_CLIENT] Send 2FA code failed:', error);
|
|
375
|
+
return {
|
|
376
|
+
success: false,
|
|
377
|
+
error: {
|
|
378
|
+
code: 'NETWORK_ERROR',
|
|
379
|
+
message: 'Failed to connect to authentication service',
|
|
380
|
+
},
|
|
381
|
+
};
|
|
382
|
+
}
|
|
383
|
+
}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Auth Utilities - Public Exports
|
|
4
|
+
*/
|
|
5
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
6
|
+
if (k2 === undefined) k2 = k;
|
|
7
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
8
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
9
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
10
|
+
}
|
|
11
|
+
Object.defineProperty(o, k2, desc);
|
|
12
|
+
}) : (function(o, m, k, k2) {
|
|
13
|
+
if (k2 === undefined) k2 = k;
|
|
14
|
+
o[k2] = m[k];
|
|
15
|
+
}));
|
|
16
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
17
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
18
|
+
};
|
|
19
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
20
|
+
__exportStar(require("./token-utils"), exports);
|
|
21
|
+
__exportStar(require("./idp-client"), exports);
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Token Utilities
|
|
3
|
+
*
|
|
4
|
+
* JWT decoding and expiry checking utilities.
|
|
5
|
+
* Extracted from auth-options.ts for clarity.
|
|
6
|
+
*
|
|
7
|
+
* @version 1.0.0
|
|
8
|
+
* @since auth-refactor-2026-01
|
|
9
|
+
*/
|
|
10
|
+
import { JwtHeader } from '../../lib/jwt-decode';
|
|
11
|
+
import type { DecodedIdpAccessToken } from '../types/auth-types';
|
|
12
|
+
export { decodeJwtHeader, extractKidFromToken, type JwtHeader } from '../../lib/jwt-decode';
|
|
13
|
+
/**
|
|
14
|
+
* Decode an IDP access token and extract claims.
|
|
15
|
+
*
|
|
16
|
+
* @param token - The JWT access token from IDP
|
|
17
|
+
* @returns Decoded token claims, or null if decode fails
|
|
18
|
+
*/
|
|
19
|
+
export declare function decodeIdpAccessToken(token: string): DecodedIdpAccessToken | null;
|
|
20
|
+
/**
|
|
21
|
+
* Decode both JWT header and payload from an IDP access token.
|
|
22
|
+
* Returns the signing key ID (kid) along with payload claims.
|
|
23
|
+
*
|
|
24
|
+
* @param token - The JWT access token from IDP
|
|
25
|
+
* @returns Object with header (including kid) and payload, or null if decode fails
|
|
26
|
+
*/
|
|
27
|
+
export declare function decodeIdpAccessTokenFull(token: string): {
|
|
28
|
+
header: JwtHeader;
|
|
29
|
+
payload: DecodedIdpAccessToken;
|
|
30
|
+
bearerKeyId: string | undefined;
|
|
31
|
+
} | null;
|
|
32
|
+
/**
|
|
33
|
+
* Extract user email from decoded token.
|
|
34
|
+
* Handles multiple possible claim names used by IDP.
|
|
35
|
+
*/
|
|
36
|
+
export declare function extractEmailFromToken(decoded: DecodedIdpAccessToken): string;
|
|
37
|
+
/**
|
|
38
|
+
* Extract roles from decoded token.
|
|
39
|
+
* Handles both 'role' and 'roles' claims, and both string and array formats.
|
|
40
|
+
*/
|
|
41
|
+
export declare function extractRolesFromToken(decoded: DecodedIdpAccessToken): string[];
|
|
42
|
+
/**
|
|
43
|
+
* Extract AMR (Authentication Methods References) from decoded token.
|
|
44
|
+
*/
|
|
45
|
+
export declare function extractAmrFromToken(decoded: DecodedIdpAccessToken): string[];
|
|
46
|
+
/**
|
|
47
|
+
* Check if a token expiry timestamp indicates the token needs refresh.
|
|
48
|
+
*
|
|
49
|
+
* @param expiresAt - Token expiry timestamp (Unix milliseconds)
|
|
50
|
+
* @param bufferMs - How early to trigger refresh (default 5 minutes)
|
|
51
|
+
* @returns true if token is expired or will expire within buffer period
|
|
52
|
+
*/
|
|
53
|
+
export declare function tokenNeedsRefresh(expiresAt: number | undefined, bufferMs?: number): boolean;
|
|
54
|
+
/**
|
|
55
|
+
* Check if a token is completely expired (past its exp time).
|
|
56
|
+
*
|
|
57
|
+
* @param expiresAt - Token expiry timestamp (Unix milliseconds)
|
|
58
|
+
* @returns true if token is expired
|
|
59
|
+
*/
|
|
60
|
+
export declare function tokenIsExpired(expiresAt: number | undefined): boolean;
|
|
61
|
+
/**
|
|
62
|
+
* Calculate milliseconds until token expires.
|
|
63
|
+
*
|
|
64
|
+
* @param expiresAt - Token expiry timestamp (Unix milliseconds)
|
|
65
|
+
* @returns Milliseconds until expiry, or 0 if already expired
|
|
66
|
+
*/
|
|
67
|
+
export declare function msUntilExpiry(expiresAt: number | undefined): number;
|
|
68
|
+
/**
|
|
69
|
+
* Convert Unix seconds (from JWT exp claim) to milliseconds.
|
|
70
|
+
*/
|
|
71
|
+
export declare function expClaimToMs(exp: number): number;
|
|
72
|
+
/**
|
|
73
|
+
* Validate that an access token's actual JWT exp matches what we have cached.
|
|
74
|
+
* This catches cases where the token was refreshed but cache wasn't updated.
|
|
75
|
+
*
|
|
76
|
+
* @param accessToken - The JWT access token
|
|
77
|
+
* @param cachedExpiresAt - What we think the expiry is (Unix ms)
|
|
78
|
+
* @returns Object with validation result and actual expiry
|
|
79
|
+
*/
|
|
80
|
+
export declare function validateTokenExpiry(accessToken: string, cachedExpiresAt: number | undefined): {
|
|
81
|
+
valid: boolean;
|
|
82
|
+
actualExpiresAt: number | null;
|
|
83
|
+
mismatch: boolean;
|
|
84
|
+
};
|