@civic/auth 0.0.1--.tsc.alpha.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.eslintignore +3 -0
- package/.eslintrc.json +10 -0
- package/.prettierignore +3 -0
- package/.prettierrc +4 -0
- package/.turbo/turbo-build.log +13 -0
- package/.turbo/turbo-lint.log +6 -0
- package/.turbo/turbo-test.log +2415 -0
- package/README.md +202 -0
- package/civic-auth-0.0.1-beta.21.tgz +0 -0
- package/dist/cjs/src/browser/storage.d.ts +6 -0
- package/dist/cjs/src/browser/storage.d.ts.map +1 -0
- package/dist/cjs/src/browser/storage.js +13 -0
- package/dist/cjs/src/browser/storage.js.map +1 -0
- package/dist/cjs/src/config.d.ts +3 -0
- package/dist/cjs/src/config.d.ts.map +1 -0
- package/dist/cjs/src/config.js +8 -0
- package/dist/cjs/src/config.js.map +1 -0
- package/dist/cjs/src/constants.d.ts +9 -0
- package/dist/cjs/src/constants.d.ts.map +1 -0
- package/dist/cjs/src/constants.js +26 -0
- package/dist/cjs/src/constants.js.map +1 -0
- package/dist/cjs/src/index.d.ts +5 -0
- package/dist/cjs/src/index.d.ts.map +1 -0
- package/dist/cjs/src/index.js +5 -0
- package/dist/cjs/src/index.js.map +1 -0
- package/dist/cjs/src/lib/cookies.d.ts +7 -0
- package/dist/cjs/src/lib/cookies.d.ts.map +1 -0
- package/dist/cjs/src/lib/cookies.js +26 -0
- package/dist/cjs/src/lib/cookies.js.map +1 -0
- package/dist/cjs/src/lib/jwt.d.ts +3 -0
- package/dist/cjs/src/lib/jwt.d.ts.map +1 -0
- package/dist/cjs/src/lib/jwt.js +13 -0
- package/dist/cjs/src/lib/jwt.js.map +1 -0
- package/dist/cjs/src/lib/logger.d.ts +26 -0
- package/dist/cjs/src/lib/logger.d.ts.map +1 -0
- package/dist/cjs/src/lib/logger.js +62 -0
- package/dist/cjs/src/lib/logger.js.map +1 -0
- package/dist/cjs/src/lib/oauth.d.ts +19 -0
- package/dist/cjs/src/lib/oauth.d.ts.map +1 -0
- package/dist/cjs/src/lib/oauth.js +67 -0
- package/dist/cjs/src/lib/oauth.js.map +1 -0
- package/dist/cjs/src/lib/postMessage.d.ts +4 -0
- package/dist/cjs/src/lib/postMessage.d.ts.map +1 -0
- package/dist/cjs/src/lib/postMessage.js +18 -0
- package/dist/cjs/src/lib/postMessage.js.map +1 -0
- package/dist/cjs/src/lib/windowUtil.d.ts +4 -0
- package/dist/cjs/src/lib/windowUtil.d.ts.map +1 -0
- package/dist/cjs/src/lib/windowUtil.js +34 -0
- package/dist/cjs/src/lib/windowUtil.js.map +1 -0
- package/dist/cjs/src/nextjs/GetUser.d.ts +6 -0
- package/dist/cjs/src/nextjs/GetUser.d.ts.map +1 -0
- package/dist/cjs/src/nextjs/GetUser.js +22 -0
- package/dist/cjs/src/nextjs/GetUser.js.map +1 -0
- package/dist/cjs/src/nextjs/client/index.d.ts +2 -0
- package/dist/cjs/src/nextjs/client/index.d.ts.map +1 -0
- package/dist/cjs/src/nextjs/client/index.js +6 -0
- package/dist/cjs/src/nextjs/client/index.js.map +1 -0
- package/dist/cjs/src/nextjs/config.d.ts +180 -0
- package/dist/cjs/src/nextjs/config.d.ts.map +1 -0
- package/dist/cjs/src/nextjs/config.js +163 -0
- package/dist/cjs/src/nextjs/config.js.map +1 -0
- package/dist/cjs/src/nextjs/cookies.d.ts +30 -0
- package/dist/cjs/src/nextjs/cookies.d.ts.map +1 -0
- package/dist/cjs/src/nextjs/cookies.js +116 -0
- package/dist/cjs/src/nextjs/cookies.js.map +1 -0
- package/dist/cjs/src/nextjs/hooks/index.d.ts +2 -0
- package/dist/cjs/src/nextjs/hooks/index.d.ts.map +1 -0
- package/dist/cjs/src/nextjs/hooks/index.js +6 -0
- package/dist/cjs/src/nextjs/hooks/index.js.map +1 -0
- package/dist/cjs/src/nextjs/hooks/useTokenCookie.d.ts +3 -0
- package/dist/cjs/src/nextjs/hooks/useTokenCookie.d.ts.map +1 -0
- package/dist/cjs/src/nextjs/hooks/useTokenCookie.js +41 -0
- package/dist/cjs/src/nextjs/hooks/useTokenCookie.js.map +1 -0
- package/dist/cjs/src/nextjs/hooks/useUserCookie.d.ts +3 -0
- package/dist/cjs/src/nextjs/hooks/useUserCookie.d.ts.map +1 -0
- package/dist/cjs/src/nextjs/hooks/useUserCookie.js +40 -0
- package/dist/cjs/src/nextjs/hooks/useUserCookie.js.map +1 -0
- package/dist/cjs/src/nextjs/index.d.ts +7 -0
- package/dist/cjs/src/nextjs/index.d.ts.map +1 -0
- package/dist/cjs/src/nextjs/index.js +20 -0
- package/dist/cjs/src/nextjs/index.js.map +1 -0
- package/dist/cjs/src/nextjs/middleware/index.d.ts +2 -0
- package/dist/cjs/src/nextjs/middleware/index.d.ts.map +1 -0
- package/dist/cjs/src/nextjs/middleware/index.js +8 -0
- package/dist/cjs/src/nextjs/middleware/index.js.map +1 -0
- package/dist/cjs/src/nextjs/middleware.d.ts +59 -0
- package/dist/cjs/src/nextjs/middleware.d.ts.map +1 -0
- package/dist/cjs/src/nextjs/middleware.js +116 -0
- package/dist/cjs/src/nextjs/middleware.js.map +1 -0
- package/dist/cjs/src/nextjs/providers/NextAuthProvider.d.ts +9 -0
- package/dist/cjs/src/nextjs/providers/NextAuthProvider.d.ts.map +1 -0
- package/dist/cjs/src/nextjs/providers/NextAuthProvider.js +77 -0
- package/dist/cjs/src/nextjs/providers/NextAuthProvider.js.map +1 -0
- package/dist/cjs/src/nextjs/routeHandler.d.ts +18 -0
- package/dist/cjs/src/nextjs/routeHandler.d.ts.map +1 -0
- package/dist/cjs/src/nextjs/routeHandler.js +208 -0
- package/dist/cjs/src/nextjs/routeHandler.js.map +1 -0
- package/dist/cjs/src/nextjs/utils.d.ts +3 -0
- package/dist/cjs/src/nextjs/utils.d.ts.map +1 -0
- package/dist/cjs/src/nextjs/utils.js +10 -0
- package/dist/cjs/src/nextjs/utils.js.map +1 -0
- package/dist/cjs/src/nextjs/worker/index.d.ts +2 -0
- package/dist/cjs/src/nextjs/worker/index.d.ts.map +1 -0
- package/dist/cjs/src/nextjs/worker/index.js +8 -0
- package/dist/cjs/src/nextjs/worker/index.js.map +1 -0
- package/dist/cjs/src/reactjs/components/NextLogOut.d.ts +7 -0
- package/dist/cjs/src/reactjs/components/NextLogOut.d.ts.map +1 -0
- package/dist/cjs/src/reactjs/components/NextLogOut.js +18 -0
- package/dist/cjs/src/reactjs/components/NextLogOut.js.map +1 -0
- package/dist/cjs/src/reactjs/components/SignInButton.d.ts +8 -0
- package/dist/cjs/src/reactjs/components/SignInButton.d.ts.map +1 -0
- package/dist/cjs/src/reactjs/components/SignInButton.js +16 -0
- package/dist/cjs/src/reactjs/components/SignInButton.js.map +1 -0
- package/dist/cjs/src/reactjs/components/SignOutButton.d.ts +6 -0
- package/dist/cjs/src/reactjs/components/SignOutButton.d.ts.map +1 -0
- package/dist/cjs/src/reactjs/components/SignOutButton.js +16 -0
- package/dist/cjs/src/reactjs/components/SignOutButton.js.map +1 -0
- package/dist/cjs/src/reactjs/components/UserButton.d.ts +8 -0
- package/dist/cjs/src/reactjs/components/UserButton.d.ts.map +1 -0
- package/dist/cjs/src/reactjs/components/UserButton.js +84 -0
- package/dist/cjs/src/reactjs/components/UserButton.js.map +1 -0
- package/dist/cjs/src/reactjs/components/index.d.ts +6 -0
- package/dist/cjs/src/reactjs/components/index.d.ts.map +1 -0
- package/dist/cjs/src/reactjs/components/index.js +14 -0
- package/dist/cjs/src/reactjs/components/index.js.map +1 -0
- package/dist/cjs/src/reactjs/hooks/index.d.ts +9 -0
- package/dist/cjs/src/reactjs/hooks/index.d.ts.map +1 -0
- package/dist/cjs/src/reactjs/hooks/index.js +20 -0
- package/dist/cjs/src/reactjs/hooks/index.js.map +1 -0
- package/dist/cjs/src/reactjs/hooks/useAuth.d.ts +3 -0
- package/dist/cjs/src/reactjs/hooks/useAuth.d.ts.map +1 -0
- package/dist/cjs/src/reactjs/hooks/useAuth.js +15 -0
- package/dist/cjs/src/reactjs/hooks/useAuth.js.map +1 -0
- package/dist/cjs/src/reactjs/hooks/useUser.d.ts +4 -0
- package/dist/cjs/src/reactjs/hooks/useUser.d.ts.map +1 -0
- package/dist/cjs/src/reactjs/hooks/useUser.js +15 -0
- package/dist/cjs/src/reactjs/hooks/useUser.js.map +1 -0
- package/dist/cjs/src/reactjs/index.d.ts +6 -0
- package/dist/cjs/src/reactjs/index.d.ts.map +1 -0
- package/dist/cjs/src/reactjs/index.js +30 -0
- package/dist/cjs/src/reactjs/index.js.map +1 -0
- package/dist/cjs/src/reactjs/providers/index.d.ts +8 -0
- package/dist/cjs/src/reactjs/providers/index.d.ts.map +1 -0
- package/dist/cjs/src/reactjs/providers/index.js +19 -0
- package/dist/cjs/src/reactjs/providers/index.js.map +1 -0
- package/dist/cjs/src/server/ServerAuthenticationResolver.d.ts +18 -0
- package/dist/cjs/src/server/ServerAuthenticationResolver.d.ts.map +1 -0
- package/dist/cjs/src/server/ServerAuthenticationResolver.js +66 -0
- package/dist/cjs/src/server/ServerAuthenticationResolver.js.map +1 -0
- package/dist/cjs/src/server/config.d.ts +16 -0
- package/dist/cjs/src/server/config.d.ts.map +1 -0
- package/dist/cjs/src/server/config.js +3 -0
- package/dist/cjs/src/server/config.js.map +1 -0
- package/dist/cjs/src/server/index.d.ts +6 -0
- package/dist/cjs/src/server/index.d.ts.map +1 -0
- package/dist/cjs/src/server/index.js +14 -0
- package/dist/cjs/src/server/index.js.map +1 -0
- package/dist/cjs/src/server/login.d.ts +17 -0
- package/dist/cjs/src/server/login.d.ts.map +1 -0
- package/dist/cjs/src/server/login.js +42 -0
- package/dist/cjs/src/server/login.js.map +1 -0
- package/dist/cjs/src/server/refresh.d.ts +7 -0
- package/dist/cjs/src/server/refresh.d.ts.map +1 -0
- package/dist/cjs/src/server/refresh.js +16 -0
- package/dist/cjs/src/server/refresh.js.map +1 -0
- package/dist/cjs/src/services/AuthenticationService.d.ts +87 -0
- package/dist/cjs/src/services/AuthenticationService.d.ts.map +1 -0
- package/dist/cjs/src/services/AuthenticationService.js +228 -0
- package/dist/cjs/src/services/AuthenticationService.js.map +1 -0
- package/dist/cjs/src/services/PKCE.d.ts +20 -0
- package/dist/cjs/src/services/PKCE.d.ts.map +1 -0
- package/dist/cjs/src/services/PKCE.js +50 -0
- package/dist/cjs/src/services/PKCE.js.map +1 -0
- package/dist/cjs/src/services/types.d.ts +23 -0
- package/dist/cjs/src/services/types.d.ts.map +1 -0
- package/dist/cjs/src/services/types.js +11 -0
- package/dist/cjs/src/services/types.js.map +1 -0
- package/dist/cjs/src/shared/AuthContext.d.ts +10 -0
- package/dist/cjs/src/shared/AuthContext.d.ts.map +1 -0
- package/dist/cjs/src/shared/AuthContext.js +6 -0
- package/dist/cjs/src/shared/AuthContext.js.map +1 -0
- package/dist/cjs/src/shared/AuthProvider.d.ts +18 -0
- package/dist/cjs/src/shared/AuthProvider.d.ts.map +1 -0
- package/dist/cjs/src/shared/AuthProvider.js +276 -0
- package/dist/cjs/src/shared/AuthProvider.js.map +1 -0
- package/dist/cjs/src/shared/CivicAuthProvider.d.ts +7 -0
- package/dist/cjs/src/shared/CivicAuthProvider.d.ts.map +1 -0
- package/dist/cjs/src/shared/CivicAuthProvider.js +23 -0
- package/dist/cjs/src/shared/CivicAuthProvider.js.map +1 -0
- package/dist/cjs/src/shared/GenericAuthenticationRefresher.d.ts +15 -0
- package/dist/cjs/src/shared/GenericAuthenticationRefresher.d.ts.map +1 -0
- package/dist/cjs/src/shared/GenericAuthenticationRefresher.js +47 -0
- package/dist/cjs/src/shared/GenericAuthenticationRefresher.js.map +1 -0
- package/dist/cjs/src/shared/UserProvider.d.ts +18 -0
- package/dist/cjs/src/shared/UserProvider.d.ts.map +1 -0
- package/dist/cjs/src/shared/UserProvider.js +65 -0
- package/dist/cjs/src/shared/UserProvider.js.map +1 -0
- package/dist/cjs/src/shared/UserSession.d.ts +12 -0
- package/dist/cjs/src/shared/UserSession.d.ts.map +1 -0
- package/dist/cjs/src/shared/UserSession.js +24 -0
- package/dist/cjs/src/shared/UserSession.js.map +1 -0
- package/dist/cjs/src/shared/components/CivicAuthIframe.d.ts +8 -0
- package/dist/cjs/src/shared/components/CivicAuthIframe.d.ts.map +1 -0
- package/dist/cjs/src/shared/components/CivicAuthIframe.js +35 -0
- package/dist/cjs/src/shared/components/CivicAuthIframe.js.map +1 -0
- package/dist/cjs/src/shared/components/CivicAuthIframeContainer.d.ts +9 -0
- package/dist/cjs/src/shared/components/CivicAuthIframeContainer.d.ts.map +1 -0
- package/dist/cjs/src/shared/components/CivicAuthIframeContainer.js +117 -0
- package/dist/cjs/src/shared/components/CivicAuthIframeContainer.js.map +1 -0
- package/dist/cjs/src/shared/components/CloseIcon.d.ts +4 -0
- package/dist/cjs/src/shared/components/CloseIcon.d.ts.map +1 -0
- package/dist/cjs/src/shared/components/CloseIcon.js +12 -0
- package/dist/cjs/src/shared/components/CloseIcon.js.map +1 -0
- package/dist/cjs/src/shared/components/LoadingIcon.d.ts +4 -0
- package/dist/cjs/src/shared/components/LoadingIcon.d.ts.map +1 -0
- package/dist/cjs/src/shared/components/LoadingIcon.js +14 -0
- package/dist/cjs/src/shared/components/LoadingIcon.js.map +1 -0
- package/dist/cjs/src/shared/hooks/index.d.ts +5 -0
- package/dist/cjs/src/shared/hooks/index.d.ts.map +1 -0
- package/dist/cjs/src/shared/hooks/index.js +12 -0
- package/dist/cjs/src/shared/hooks/index.js.map +1 -0
- package/dist/cjs/src/shared/hooks/useAuth.d.ts +3 -0
- package/dist/cjs/src/shared/hooks/useAuth.d.ts.map +1 -0
- package/dist/cjs/src/shared/hooks/useAuth.js +15 -0
- package/dist/cjs/src/shared/hooks/useAuth.js.map +1 -0
- package/dist/cjs/src/shared/hooks/useConfig.d.ts +3 -0
- package/dist/cjs/src/shared/hooks/useConfig.d.ts.map +1 -0
- package/dist/cjs/src/shared/hooks/useConfig.js +16 -0
- package/dist/cjs/src/shared/hooks/useConfig.js.map +1 -0
- package/dist/cjs/src/shared/hooks/useIframe.d.ts +3 -0
- package/dist/cjs/src/shared/hooks/useIframe.d.ts.map +1 -0
- package/dist/cjs/src/shared/hooks/useIframe.js +16 -0
- package/dist/cjs/src/shared/hooks/useIframe.js.map +1 -0
- package/dist/cjs/src/shared/hooks/useSession.d.ts +3 -0
- package/dist/cjs/src/shared/hooks/useSession.d.ts.map +1 -0
- package/dist/cjs/src/shared/hooks/useSession.js +16 -0
- package/dist/cjs/src/shared/hooks/useSession.js.map +1 -0
- package/dist/cjs/src/shared/hooks/useToken.d.ts +3 -0
- package/dist/cjs/src/shared/hooks/useToken.d.ts.map +1 -0
- package/dist/cjs/src/shared/hooks/useToken.js +15 -0
- package/dist/cjs/src/shared/hooks/useToken.js.map +1 -0
- package/dist/cjs/src/shared/lib/GenericAuthenticationRefresher.d.ts +15 -0
- package/dist/cjs/src/shared/lib/GenericAuthenticationRefresher.d.ts.map +1 -0
- package/dist/cjs/src/shared/lib/GenericAuthenticationRefresher.js +47 -0
- package/dist/cjs/src/shared/lib/GenericAuthenticationRefresher.js.map +1 -0
- package/dist/cjs/src/shared/lib/UserSession.d.ts +12 -0
- package/dist/cjs/src/shared/lib/UserSession.d.ts.map +1 -0
- package/dist/cjs/src/shared/lib/UserSession.js +24 -0
- package/dist/cjs/src/shared/lib/UserSession.js.map +1 -0
- package/dist/cjs/src/shared/lib/session.d.ts +3 -0
- package/dist/cjs/src/shared/lib/session.d.ts.map +1 -0
- package/dist/cjs/src/shared/lib/session.js +13 -0
- package/dist/cjs/src/shared/lib/session.js.map +1 -0
- package/dist/cjs/src/shared/lib/storage.d.ts +25 -0
- package/dist/cjs/src/shared/lib/storage.d.ts.map +1 -0
- package/dist/cjs/src/shared/lib/storage.js +21 -0
- package/dist/cjs/src/shared/lib/storage.js.map +1 -0
- package/dist/cjs/src/shared/lib/types.d.ts +21 -0
- package/dist/cjs/src/shared/lib/types.d.ts.map +1 -0
- package/dist/cjs/src/shared/lib/types.js +18 -0
- package/dist/cjs/src/shared/lib/types.js.map +1 -0
- package/dist/cjs/src/shared/lib/util.d.ts +33 -0
- package/dist/cjs/src/shared/lib/util.d.ts.map +1 -0
- package/dist/cjs/src/shared/lib/util.js +164 -0
- package/dist/cjs/src/shared/lib/util.js.map +1 -0
- package/dist/cjs/src/shared/providers/AuthContext.d.ts +10 -0
- package/dist/cjs/src/shared/providers/AuthContext.d.ts.map +1 -0
- package/dist/cjs/src/shared/providers/AuthContext.js +6 -0
- package/dist/cjs/src/shared/providers/AuthContext.js.map +1 -0
- package/dist/cjs/src/shared/providers/AuthProvider.d.ts +18 -0
- package/dist/cjs/src/shared/providers/AuthProvider.d.ts.map +1 -0
- package/dist/cjs/src/shared/providers/AuthProvider.js +271 -0
- package/dist/cjs/src/shared/providers/AuthProvider.js.map +1 -0
- package/dist/cjs/src/shared/providers/CivicAuthProvider.d.ts +6 -0
- package/dist/cjs/src/shared/providers/CivicAuthProvider.d.ts.map +1 -0
- package/dist/cjs/src/shared/providers/CivicAuthProvider.js +23 -0
- package/dist/cjs/src/shared/providers/CivicAuthProvider.js.map +1 -0
- package/dist/cjs/src/shared/providers/ConfigProvider.d.ts +21 -0
- package/dist/cjs/src/shared/providers/ConfigProvider.d.ts.map +1 -0
- package/dist/cjs/src/shared/providers/ConfigProvider.js +46 -0
- package/dist/cjs/src/shared/providers/ConfigProvider.js.map +1 -0
- package/dist/cjs/src/shared/providers/IframeProvider.d.ts +16 -0
- package/dist/cjs/src/shared/providers/IframeProvider.d.ts.map +1 -0
- package/dist/cjs/src/shared/providers/IframeProvider.js +38 -0
- package/dist/cjs/src/shared/providers/IframeProvider.js.map +1 -0
- package/dist/cjs/src/shared/providers/SessionProvider.d.ts +13 -0
- package/dist/cjs/src/shared/providers/SessionProvider.d.ts.map +1 -0
- package/dist/cjs/src/shared/providers/SessionProvider.js +40 -0
- package/dist/cjs/src/shared/providers/SessionProvider.js.map +1 -0
- package/dist/cjs/src/shared/providers/TokenProvider.d.ts +18 -0
- package/dist/cjs/src/shared/providers/TokenProvider.d.ts.map +1 -0
- package/dist/cjs/src/shared/providers/TokenProvider.js +80 -0
- package/dist/cjs/src/shared/providers/TokenProvider.js.map +1 -0
- package/dist/cjs/src/shared/providers/UserProvider.d.ts +18 -0
- package/dist/cjs/src/shared/providers/UserProvider.d.ts.map +1 -0
- package/dist/cjs/src/shared/providers/UserProvider.js +65 -0
- package/dist/cjs/src/shared/providers/UserProvider.js.map +1 -0
- package/dist/cjs/src/shared/session.d.ts +3 -0
- package/dist/cjs/src/shared/session.d.ts.map +1 -0
- package/dist/cjs/src/shared/session.js +13 -0
- package/dist/cjs/src/shared/session.js.map +1 -0
- package/dist/cjs/src/shared/storage.d.ts +25 -0
- package/dist/cjs/src/shared/storage.d.ts.map +1 -0
- package/dist/cjs/src/shared/storage.js +21 -0
- package/dist/cjs/src/shared/storage.js.map +1 -0
- package/dist/cjs/src/shared/types.d.ts +21 -0
- package/dist/cjs/src/shared/types.d.ts.map +1 -0
- package/dist/cjs/src/shared/types.js +18 -0
- package/dist/cjs/src/shared/types.js.map +1 -0
- package/dist/cjs/src/shared/util.d.ts +33 -0
- package/dist/cjs/src/shared/util.d.ts.map +1 -0
- package/dist/cjs/src/shared/util.js +164 -0
- package/dist/cjs/src/shared/util.js.map +1 -0
- package/dist/cjs/src/types.d.ts +146 -0
- package/dist/cjs/src/types.d.ts.map +1 -0
- package/dist/cjs/src/types.js +3 -0
- package/dist/cjs/src/types.js.map +1 -0
- package/dist/cjs/src/utils.d.ts +17 -0
- package/dist/cjs/src/utils.d.ts.map +1 -0
- package/dist/cjs/src/utils.js +53 -0
- package/dist/cjs/src/utils.js.map +1 -0
- package/dist/cjs/src/worker/index.d.ts +2 -0
- package/dist/cjs/src/worker/index.d.ts.map +1 -0
- package/dist/cjs/src/worker/index.js +8 -0
- package/dist/cjs/src/worker/index.js.map +1 -0
- package/dist/cjs/tsconfig.build.tsbuildinfo +1 -0
- package/dist/cjs/tsconfig.cjs.tsbuildinfo +1 -0
- package/dist/esm/src/browser/storage.d.ts +6 -0
- package/dist/esm/src/browser/storage.d.ts.map +1 -0
- package/dist/esm/src/browser/storage.js +9 -0
- package/dist/esm/src/browser/storage.js.map +1 -0
- package/dist/esm/src/config.d.ts +3 -0
- package/dist/esm/src/config.d.ts.map +1 -0
- package/dist/esm/src/config.js +5 -0
- package/dist/esm/src/config.js.map +1 -0
- package/dist/esm/src/constants.d.ts +9 -0
- package/dist/esm/src/constants.d.ts.map +1 -0
- package/dist/esm/src/constants.js +17 -0
- package/dist/esm/src/constants.js.map +1 -0
- package/dist/esm/src/index.d.ts +5 -0
- package/dist/esm/src/index.d.ts.map +1 -0
- package/dist/esm/src/index.js +3 -0
- package/dist/esm/src/index.js.map +1 -0
- package/dist/esm/src/lib/cookies.d.ts +7 -0
- package/dist/esm/src/lib/cookies.d.ts.map +1 -0
- package/dist/esm/src/lib/cookies.js +23 -0
- package/dist/esm/src/lib/cookies.js.map +1 -0
- package/dist/esm/src/lib/jwt.d.ts +3 -0
- package/dist/esm/src/lib/jwt.d.ts.map +1 -0
- package/dist/esm/src/lib/jwt.js +9 -0
- package/dist/esm/src/lib/jwt.js.map +1 -0
- package/dist/esm/src/lib/logger.d.ts +26 -0
- package/dist/esm/src/lib/logger.d.ts.map +1 -0
- package/dist/esm/src/lib/logger.js +55 -0
- package/dist/esm/src/lib/logger.js.map +1 -0
- package/dist/esm/src/lib/oauth.d.ts +19 -0
- package/dist/esm/src/lib/oauth.d.ts.map +1 -0
- package/dist/esm/src/lib/oauth.js +60 -0
- package/dist/esm/src/lib/oauth.js.map +1 -0
- package/dist/esm/src/lib/postMessage.d.ts +4 -0
- package/dist/esm/src/lib/postMessage.d.ts.map +1 -0
- package/dist/esm/src/lib/postMessage.js +15 -0
- package/dist/esm/src/lib/postMessage.js.map +1 -0
- package/dist/esm/src/lib/windowUtil.d.ts +4 -0
- package/dist/esm/src/lib/windowUtil.d.ts.map +1 -0
- package/dist/esm/src/lib/windowUtil.js +30 -0
- package/dist/esm/src/lib/windowUtil.js.map +1 -0
- package/dist/esm/src/nextjs/GetUser.d.ts +6 -0
- package/dist/esm/src/nextjs/GetUser.d.ts.map +1 -0
- package/dist/esm/src/nextjs/GetUser.js +18 -0
- package/dist/esm/src/nextjs/GetUser.js.map +1 -0
- package/dist/esm/src/nextjs/client/index.d.ts +2 -0
- package/dist/esm/src/nextjs/client/index.d.ts.map +1 -0
- package/dist/esm/src/nextjs/client/index.js +2 -0
- package/dist/esm/src/nextjs/client/index.js.map +1 -0
- package/dist/esm/src/nextjs/config.d.ts +180 -0
- package/dist/esm/src/nextjs/config.d.ts.map +1 -0
- package/dist/esm/src/nextjs/config.js +158 -0
- package/dist/esm/src/nextjs/config.js.map +1 -0
- package/dist/esm/src/nextjs/cookies.d.ts +30 -0
- package/dist/esm/src/nextjs/cookies.d.ts.map +1 -0
- package/dist/esm/src/nextjs/cookies.js +109 -0
- package/dist/esm/src/nextjs/cookies.js.map +1 -0
- package/dist/esm/src/nextjs/hooks/index.d.ts +2 -0
- package/dist/esm/src/nextjs/hooks/index.d.ts.map +1 -0
- package/dist/esm/src/nextjs/hooks/index.js +2 -0
- package/dist/esm/src/nextjs/hooks/index.js.map +1 -0
- package/dist/esm/src/nextjs/hooks/useTokenCookie.d.ts +3 -0
- package/dist/esm/src/nextjs/hooks/useTokenCookie.d.ts.map +1 -0
- package/dist/esm/src/nextjs/hooks/useTokenCookie.js +37 -0
- package/dist/esm/src/nextjs/hooks/useTokenCookie.js.map +1 -0
- package/dist/esm/src/nextjs/hooks/useUserCookie.d.ts +3 -0
- package/dist/esm/src/nextjs/hooks/useUserCookie.d.ts.map +1 -0
- package/dist/esm/src/nextjs/hooks/useUserCookie.js +36 -0
- package/dist/esm/src/nextjs/hooks/useUserCookie.js.map +1 -0
- package/dist/esm/src/nextjs/index.d.ts +7 -0
- package/dist/esm/src/nextjs/index.d.ts.map +1 -0
- package/dist/esm/src/nextjs/index.js +6 -0
- package/dist/esm/src/nextjs/index.js.map +1 -0
- package/dist/esm/src/nextjs/middleware/index.d.ts +2 -0
- package/dist/esm/src/nextjs/middleware/index.d.ts.map +1 -0
- package/dist/esm/src/nextjs/middleware/index.js +2 -0
- package/dist/esm/src/nextjs/middleware/index.js.map +1 -0
- package/dist/esm/src/nextjs/middleware.d.ts +59 -0
- package/dist/esm/src/nextjs/middleware.d.ts.map +1 -0
- package/dist/esm/src/nextjs/middleware.js +107 -0
- package/dist/esm/src/nextjs/middleware.js.map +1 -0
- package/dist/esm/src/nextjs/providers/NextAuthProvider.d.ts +9 -0
- package/dist/esm/src/nextjs/providers/NextAuthProvider.d.ts.map +1 -0
- package/dist/esm/src/nextjs/providers/NextAuthProvider.js +51 -0
- package/dist/esm/src/nextjs/providers/NextAuthProvider.js.map +1 -0
- package/dist/esm/src/nextjs/routeHandler.d.ts +18 -0
- package/dist/esm/src/nextjs/routeHandler.d.ts.map +1 -0
- package/dist/esm/src/nextjs/routeHandler.js +203 -0
- package/dist/esm/src/nextjs/routeHandler.js.map +1 -0
- package/dist/esm/src/nextjs/utils.d.ts +3 -0
- package/dist/esm/src/nextjs/utils.d.ts.map +1 -0
- package/dist/esm/src/nextjs/utils.js +6 -0
- package/dist/esm/src/nextjs/utils.js.map +1 -0
- package/dist/esm/src/nextjs/worker/index.d.ts +2 -0
- package/dist/esm/src/nextjs/worker/index.d.ts.map +1 -0
- package/dist/esm/src/nextjs/worker/index.js +2 -0
- package/dist/esm/src/nextjs/worker/index.js.map +1 -0
- package/dist/esm/src/reactjs/components/NextLogOut.d.ts +7 -0
- package/dist/esm/src/reactjs/components/NextLogOut.d.ts.map +1 -0
- package/dist/esm/src/reactjs/components/NextLogOut.js +12 -0
- package/dist/esm/src/reactjs/components/NextLogOut.js.map +1 -0
- package/dist/esm/src/reactjs/components/SignInButton.d.ts +8 -0
- package/dist/esm/src/reactjs/components/SignInButton.d.ts.map +1 -0
- package/dist/esm/src/reactjs/components/SignInButton.js +10 -0
- package/dist/esm/src/reactjs/components/SignInButton.js.map +1 -0
- package/dist/esm/src/reactjs/components/SignOutButton.d.ts +6 -0
- package/dist/esm/src/reactjs/components/SignOutButton.d.ts.map +1 -0
- package/dist/esm/src/reactjs/components/SignOutButton.js +10 -0
- package/dist/esm/src/reactjs/components/SignOutButton.js.map +1 -0
- package/dist/esm/src/reactjs/components/UserButton.d.ts +8 -0
- package/dist/esm/src/reactjs/components/UserButton.d.ts.map +1 -0
- package/dist/esm/src/reactjs/components/UserButton.js +58 -0
- package/dist/esm/src/reactjs/components/UserButton.js.map +1 -0
- package/dist/esm/src/reactjs/components/index.d.ts +6 -0
- package/dist/esm/src/reactjs/components/index.d.ts.map +1 -0
- package/dist/esm/src/reactjs/components/index.js +6 -0
- package/dist/esm/src/reactjs/components/index.js.map +1 -0
- package/dist/esm/src/reactjs/hooks/index.d.ts +9 -0
- package/dist/esm/src/reactjs/hooks/index.d.ts.map +1 -0
- package/dist/esm/src/reactjs/hooks/index.js +9 -0
- package/dist/esm/src/reactjs/hooks/index.js.map +1 -0
- package/dist/esm/src/reactjs/hooks/useAuth.d.ts +3 -0
- package/dist/esm/src/reactjs/hooks/useAuth.d.ts.map +1 -0
- package/dist/esm/src/reactjs/hooks/useAuth.js +12 -0
- package/dist/esm/src/reactjs/hooks/useAuth.js.map +1 -0
- package/dist/esm/src/reactjs/hooks/useUser.d.ts +4 -0
- package/dist/esm/src/reactjs/hooks/useUser.d.ts.map +1 -0
- package/dist/esm/src/reactjs/hooks/useUser.js +12 -0
- package/dist/esm/src/reactjs/hooks/useUser.js.map +1 -0
- package/dist/esm/src/reactjs/index.d.ts +6 -0
- package/dist/esm/src/reactjs/index.d.ts.map +1 -0
- package/dist/esm/src/reactjs/index.js +8 -0
- package/dist/esm/src/reactjs/index.js.map +1 -0
- package/dist/esm/src/reactjs/providers/index.d.ts +8 -0
- package/dist/esm/src/reactjs/providers/index.d.ts.map +1 -0
- package/dist/esm/src/reactjs/providers/index.js +7 -0
- package/dist/esm/src/reactjs/providers/index.js.map +1 -0
- package/dist/esm/src/server/ServerAuthenticationResolver.d.ts +18 -0
- package/dist/esm/src/server/ServerAuthenticationResolver.d.ts.map +1 -0
- package/dist/esm/src/server/ServerAuthenticationResolver.js +62 -0
- package/dist/esm/src/server/ServerAuthenticationResolver.js.map +1 -0
- package/dist/esm/src/server/config.d.ts +16 -0
- package/dist/esm/src/server/config.d.ts.map +1 -0
- package/dist/esm/src/server/config.js +2 -0
- package/dist/esm/src/server/config.js.map +1 -0
- package/dist/esm/src/server/index.d.ts +6 -0
- package/dist/esm/src/server/index.d.ts.map +1 -0
- package/dist/esm/src/server/index.js +5 -0
- package/dist/esm/src/server/index.js.map +1 -0
- package/dist/esm/src/server/login.d.ts +17 -0
- package/dist/esm/src/server/login.d.ts.map +1 -0
- package/dist/esm/src/server/login.js +37 -0
- package/dist/esm/src/server/login.js.map +1 -0
- package/dist/esm/src/server/refresh.d.ts +7 -0
- package/dist/esm/src/server/refresh.d.ts.map +1 -0
- package/dist/esm/src/server/refresh.js +13 -0
- package/dist/esm/src/server/refresh.js.map +1 -0
- package/dist/esm/src/services/AuthenticationService.d.ts +87 -0
- package/dist/esm/src/services/AuthenticationService.d.ts.map +1 -0
- package/dist/esm/src/services/AuthenticationService.js +222 -0
- package/dist/esm/src/services/AuthenticationService.js.map +1 -0
- package/dist/esm/src/services/PKCE.d.ts +20 -0
- package/dist/esm/src/services/PKCE.d.ts.map +1 -0
- package/dist/esm/src/services/PKCE.js +44 -0
- package/dist/esm/src/services/PKCE.js.map +1 -0
- package/dist/esm/src/services/types.d.ts +23 -0
- package/dist/esm/src/services/types.d.ts.map +1 -0
- package/dist/esm/src/services/types.js +7 -0
- package/dist/esm/src/services/types.js.map +1 -0
- package/dist/esm/src/shared/AuthContext.d.ts +10 -0
- package/dist/esm/src/shared/AuthContext.d.ts.map +1 -0
- package/dist/esm/src/shared/AuthContext.js +3 -0
- package/dist/esm/src/shared/AuthContext.js.map +1 -0
- package/dist/esm/src/shared/AuthProvider.d.ts +18 -0
- package/dist/esm/src/shared/AuthProvider.d.ts.map +1 -0
- package/dist/esm/src/shared/AuthProvider.js +250 -0
- package/dist/esm/src/shared/AuthProvider.js.map +1 -0
- package/dist/esm/src/shared/CivicAuthProvider.d.ts +7 -0
- package/dist/esm/src/shared/CivicAuthProvider.d.ts.map +1 -0
- package/dist/esm/src/shared/CivicAuthProvider.js +17 -0
- package/dist/esm/src/shared/CivicAuthProvider.js.map +1 -0
- package/dist/esm/src/shared/GenericAuthenticationRefresher.d.ts +15 -0
- package/dist/esm/src/shared/GenericAuthenticationRefresher.d.ts.map +1 -0
- package/dist/esm/src/shared/GenericAuthenticationRefresher.js +43 -0
- package/dist/esm/src/shared/GenericAuthenticationRefresher.js.map +1 -0
- package/dist/esm/src/shared/UserProvider.d.ts +18 -0
- package/dist/esm/src/shared/UserProvider.d.ts.map +1 -0
- package/dist/esm/src/shared/UserProvider.js +38 -0
- package/dist/esm/src/shared/UserProvider.js.map +1 -0
- package/dist/esm/src/shared/UserSession.d.ts +12 -0
- package/dist/esm/src/shared/UserSession.d.ts.map +1 -0
- package/dist/esm/src/shared/UserSession.js +20 -0
- package/dist/esm/src/shared/UserSession.js.map +1 -0
- package/dist/esm/src/shared/components/CivicAuthIframe.d.ts +8 -0
- package/dist/esm/src/shared/components/CivicAuthIframe.d.ts.map +1 -0
- package/dist/esm/src/shared/components/CivicAuthIframe.js +9 -0
- package/dist/esm/src/shared/components/CivicAuthIframe.js.map +1 -0
- package/dist/esm/src/shared/components/CivicAuthIframeContainer.d.ts +9 -0
- package/dist/esm/src/shared/components/CivicAuthIframeContainer.d.ts.map +1 -0
- package/dist/esm/src/shared/components/CivicAuthIframeContainer.js +91 -0
- package/dist/esm/src/shared/components/CivicAuthIframeContainer.js.map +1 -0
- package/dist/esm/src/shared/components/CloseIcon.d.ts +4 -0
- package/dist/esm/src/shared/components/CloseIcon.d.ts.map +1 -0
- package/dist/esm/src/shared/components/CloseIcon.js +6 -0
- package/dist/esm/src/shared/components/CloseIcon.js.map +1 -0
- package/dist/esm/src/shared/components/LoadingIcon.d.ts +4 -0
- package/dist/esm/src/shared/components/LoadingIcon.d.ts.map +1 -0
- package/dist/esm/src/shared/components/LoadingIcon.js +8 -0
- package/dist/esm/src/shared/components/LoadingIcon.js.map +1 -0
- package/dist/esm/src/shared/hooks/index.d.ts +5 -0
- package/dist/esm/src/shared/hooks/index.d.ts.map +1 -0
- package/dist/esm/src/shared/hooks/index.js +5 -0
- package/dist/esm/src/shared/hooks/index.js.map +1 -0
- package/dist/esm/src/shared/hooks/useAuth.d.ts +3 -0
- package/dist/esm/src/shared/hooks/useAuth.d.ts.map +1 -0
- package/dist/esm/src/shared/hooks/useAuth.js +12 -0
- package/dist/esm/src/shared/hooks/useAuth.js.map +1 -0
- package/dist/esm/src/shared/hooks/useConfig.d.ts +3 -0
- package/dist/esm/src/shared/hooks/useConfig.d.ts.map +1 -0
- package/dist/esm/src/shared/hooks/useConfig.js +13 -0
- package/dist/esm/src/shared/hooks/useConfig.js.map +1 -0
- package/dist/esm/src/shared/hooks/useIframe.d.ts +3 -0
- package/dist/esm/src/shared/hooks/useIframe.d.ts.map +1 -0
- package/dist/esm/src/shared/hooks/useIframe.js +13 -0
- package/dist/esm/src/shared/hooks/useIframe.js.map +1 -0
- package/dist/esm/src/shared/hooks/useSession.d.ts +3 -0
- package/dist/esm/src/shared/hooks/useSession.d.ts.map +1 -0
- package/dist/esm/src/shared/hooks/useSession.js +13 -0
- package/dist/esm/src/shared/hooks/useSession.js.map +1 -0
- package/dist/esm/src/shared/hooks/useToken.d.ts +3 -0
- package/dist/esm/src/shared/hooks/useToken.d.ts.map +1 -0
- package/dist/esm/src/shared/hooks/useToken.js +12 -0
- package/dist/esm/src/shared/hooks/useToken.js.map +1 -0
- package/dist/esm/src/shared/lib/GenericAuthenticationRefresher.d.ts +15 -0
- package/dist/esm/src/shared/lib/GenericAuthenticationRefresher.d.ts.map +1 -0
- package/dist/esm/src/shared/lib/GenericAuthenticationRefresher.js +43 -0
- package/dist/esm/src/shared/lib/GenericAuthenticationRefresher.js.map +1 -0
- package/dist/esm/src/shared/lib/UserSession.d.ts +12 -0
- package/dist/esm/src/shared/lib/UserSession.d.ts.map +1 -0
- package/dist/esm/src/shared/lib/UserSession.js +20 -0
- package/dist/esm/src/shared/lib/UserSession.js.map +1 -0
- package/dist/esm/src/shared/lib/session.d.ts +3 -0
- package/dist/esm/src/shared/lib/session.d.ts.map +1 -0
- package/dist/esm/src/shared/lib/session.js +10 -0
- package/dist/esm/src/shared/lib/session.js.map +1 -0
- package/dist/esm/src/shared/lib/storage.d.ts +25 -0
- package/dist/esm/src/shared/lib/storage.d.ts.map +1 -0
- package/dist/esm/src/shared/lib/storage.js +17 -0
- package/dist/esm/src/shared/lib/storage.js.map +1 -0
- package/dist/esm/src/shared/lib/types.d.ts +21 -0
- package/dist/esm/src/shared/lib/types.d.ts.map +1 -0
- package/dist/esm/src/shared/lib/types.js +15 -0
- package/dist/esm/src/shared/lib/types.js.map +1 -0
- package/dist/esm/src/shared/lib/util.d.ts +33 -0
- package/dist/esm/src/shared/lib/util.d.ts.map +1 -0
- package/dist/esm/src/shared/lib/util.js +128 -0
- package/dist/esm/src/shared/lib/util.js.map +1 -0
- package/dist/esm/src/shared/providers/AuthContext.d.ts +10 -0
- package/dist/esm/src/shared/providers/AuthContext.d.ts.map +1 -0
- package/dist/esm/src/shared/providers/AuthContext.js +3 -0
- package/dist/esm/src/shared/providers/AuthContext.js.map +1 -0
- package/dist/esm/src/shared/providers/AuthProvider.d.ts +18 -0
- package/dist/esm/src/shared/providers/AuthProvider.d.ts.map +1 -0
- package/dist/esm/src/shared/providers/AuthProvider.js +245 -0
- package/dist/esm/src/shared/providers/AuthProvider.js.map +1 -0
- package/dist/esm/src/shared/providers/CivicAuthProvider.d.ts +6 -0
- package/dist/esm/src/shared/providers/CivicAuthProvider.d.ts.map +1 -0
- package/dist/esm/src/shared/providers/CivicAuthProvider.js +17 -0
- package/dist/esm/src/shared/providers/CivicAuthProvider.js.map +1 -0
- package/dist/esm/src/shared/providers/ConfigProvider.d.ts +21 -0
- package/dist/esm/src/shared/providers/ConfigProvider.d.ts.map +1 -0
- package/dist/esm/src/shared/providers/ConfigProvider.js +19 -0
- package/dist/esm/src/shared/providers/ConfigProvider.js.map +1 -0
- package/dist/esm/src/shared/providers/IframeProvider.d.ts +16 -0
- package/dist/esm/src/shared/providers/IframeProvider.d.ts.map +1 -0
- package/dist/esm/src/shared/providers/IframeProvider.js +11 -0
- package/dist/esm/src/shared/providers/IframeProvider.js.map +1 -0
- package/dist/esm/src/shared/providers/SessionProvider.d.ts +13 -0
- package/dist/esm/src/shared/providers/SessionProvider.d.ts.map +1 -0
- package/dist/esm/src/shared/providers/SessionProvider.js +13 -0
- package/dist/esm/src/shared/providers/SessionProvider.js.map +1 -0
- package/dist/esm/src/shared/providers/TokenProvider.d.ts +18 -0
- package/dist/esm/src/shared/providers/TokenProvider.d.ts.map +1 -0
- package/dist/esm/src/shared/providers/TokenProvider.js +53 -0
- package/dist/esm/src/shared/providers/TokenProvider.js.map +1 -0
- package/dist/esm/src/shared/providers/UserProvider.d.ts +18 -0
- package/dist/esm/src/shared/providers/UserProvider.d.ts.map +1 -0
- package/dist/esm/src/shared/providers/UserProvider.js +38 -0
- package/dist/esm/src/shared/providers/UserProvider.js.map +1 -0
- package/dist/esm/src/shared/session.d.ts +3 -0
- package/dist/esm/src/shared/session.d.ts.map +1 -0
- package/dist/esm/src/shared/session.js +10 -0
- package/dist/esm/src/shared/session.js.map +1 -0
- package/dist/esm/src/shared/storage.d.ts +25 -0
- package/dist/esm/src/shared/storage.d.ts.map +1 -0
- package/dist/esm/src/shared/storage.js +17 -0
- package/dist/esm/src/shared/storage.js.map +1 -0
- package/dist/esm/src/shared/types.d.ts +21 -0
- package/dist/esm/src/shared/types.d.ts.map +1 -0
- package/dist/esm/src/shared/types.js +15 -0
- package/dist/esm/src/shared/types.js.map +1 -0
- package/dist/esm/src/shared/util.d.ts +33 -0
- package/dist/esm/src/shared/util.d.ts.map +1 -0
- package/dist/esm/src/shared/util.js +128 -0
- package/dist/esm/src/shared/util.js.map +1 -0
- package/dist/esm/src/types.d.ts +146 -0
- package/dist/esm/src/types.d.ts.map +1 -0
- package/dist/esm/src/types.js +2 -0
- package/dist/esm/src/types.js.map +1 -0
- package/dist/esm/src/utils.d.ts +17 -0
- package/dist/esm/src/utils.d.ts.map +1 -0
- package/dist/esm/src/utils.js +48 -0
- package/dist/esm/src/utils.js.map +1 -0
- package/dist/esm/src/worker/index.d.ts +2 -0
- package/dist/esm/src/worker/index.d.ts.map +1 -0
- package/dist/esm/src/worker/index.js +2 -0
- package/dist/esm/src/worker/index.js.map +1 -0
- package/dist/esm/tsconfig.build.tsbuildinfo +1 -0
- package/dist/esm/tsconfig.esm.tsbuildinfo +1 -0
- package/package.json +115 -0
- package/postcss.config.cjs +6 -0
- package/src/browser/storage.ts +11 -0
- package/src/config.ts +6 -0
- package/src/constants.ts +29 -0
- package/src/index.ts +18 -0
- package/src/lib/cookies.ts +28 -0
- package/src/lib/jwt.ts +15 -0
- package/src/lib/logger.ts +72 -0
- package/src/lib/oauth.ts +83 -0
- package/src/lib/postMessage.ts +22 -0
- package/src/lib/windowUtil.ts +29 -0
- package/src/nextjs/GetUser.ts +22 -0
- package/src/nextjs/client/index.ts +4 -0
- package/src/nextjs/config.ts +203 -0
- package/src/nextjs/cookies.ts +166 -0
- package/src/nextjs/hooks/index.ts +1 -0
- package/src/nextjs/hooks/useTokenCookie.ts +41 -0
- package/src/nextjs/hooks/useUserCookie.ts +41 -0
- package/src/nextjs/index.ts +24 -0
- package/src/nextjs/middleware/index.ts +1 -0
- package/src/nextjs/middleware.ts +155 -0
- package/src/nextjs/providers/NextAuthProvider.tsx +89 -0
- package/src/nextjs/routeHandler.ts +276 -0
- package/src/nextjs/utils.ts +10 -0
- package/src/reactjs/components/SignInButton.tsx +30 -0
- package/src/reactjs/components/SignOutButton.tsx +22 -0
- package/src/reactjs/components/UserButton.tsx +153 -0
- package/src/reactjs/components/index.ts +5 -0
- package/src/reactjs/hooks/index.ts +8 -0
- package/src/reactjs/hooks/useAuth.ts +15 -0
- package/src/reactjs/hooks/useUser.ts +20 -0
- package/src/reactjs/index.ts +19 -0
- package/src/reactjs/providers/index.ts +27 -0
- package/src/server/ServerAuthenticationResolver.ts +107 -0
- package/src/server/config.ts +17 -0
- package/src/server/index.ts +12 -0
- package/src/server/login.ts +58 -0
- package/src/server/refresh.ts +23 -0
- package/src/services/AuthenticationService.ts +334 -0
- package/src/services/PKCE.ts +43 -0
- package/src/services/types.ts +54 -0
- package/src/shared/components/CivicAuthIframe.tsx +26 -0
- package/src/shared/components/CivicAuthIframeContainer.tsx +150 -0
- package/src/shared/components/CloseIcon.tsx +21 -0
- package/src/shared/components/LoadingIcon.tsx +25 -0
- package/src/shared/hooks/index.ts +4 -0
- package/src/shared/hooks/useAuth.ts +15 -0
- package/src/shared/hooks/useConfig.ts +14 -0
- package/src/shared/hooks/useIframe.ts +14 -0
- package/src/shared/hooks/useSession.ts +14 -0
- package/src/shared/hooks/useToken.ts +15 -0
- package/src/shared/lib/GenericAuthenticationRefresher.ts +75 -0
- package/src/shared/lib/UserSession.ts +25 -0
- package/src/shared/lib/session.ts +11 -0
- package/src/shared/lib/storage.ts +40 -0
- package/src/shared/lib/types.ts +25 -0
- package/src/shared/lib/util.ts +217 -0
- package/src/shared/providers/AuthContext.tsx +11 -0
- package/src/shared/providers/AuthProvider.tsx +364 -0
- package/src/shared/providers/CivicAuthProvider.tsx +34 -0
- package/src/shared/providers/ConfigProvider.tsx +50 -0
- package/src/shared/providers/IframeProvider.tsx +34 -0
- package/src/shared/providers/SessionProvider.tsx +29 -0
- package/src/shared/providers/TokenProvider.tsx +78 -0
- package/src/shared/providers/UserProvider.tsx +80 -0
- package/src/styles.css +3 -0
- package/src/types.ts +227 -0
- package/src/utils.ts +65 -0
- package/tailwind.config.js +8 -0
- package/test/integration/sdk.test.tsx +266 -0
- package/test/support/fixtures.ts +56 -0
- package/test/support/tokens.json +26 -0
- package/test/unit/lib/oauth.test.ts +72 -0
- package/test/unit/logger.test.ts +175 -0
- package/test/unit/nextjs/NextAuthProvider.test.tsx +38 -0
- package/test/unit/nextjs/config.test.ts +201 -0
- package/test/unit/nextjs/getUser.test.ts +41 -0
- package/test/unit/nextjs/middleware.test.ts +138 -0
- package/test/unit/nextjs/routeHandler.test.ts +369 -0
- package/test/unit/nextjs/utils.test.ts +26 -0
- package/test/unit/publicApi/__snapshots__/apiSnapshot.test.ts.snap +19 -0
- package/test/unit/publicApi/apiSnapshot.test.ts +11 -0
- package/test/unit/react/components/SignInButton.test.tsx +50 -0
- package/test/unit/react/components/SignOutButton.test.tsx +49 -0
- package/test/unit/server/login.test.ts +179 -0
- package/test/unit/server/session.test.ts +51 -0
- package/test/unit/services/AuthenticationService.test.ts +152 -0
- package/test/unit/services/ServerAuthenticationResolver.test.ts +110 -0
- package/test/unit/shared/GenericAuthenticationRefresher.test.ts +89 -0
- package/test/unit/shared/UserSession.test.ts +42 -0
- package/test/unit/shared/components/CivicAuthIframeContainer.test.tsx +154 -0
- package/test/unit/shared/storage.test.ts +67 -0
- package/test/unit/utils.test.ts +48 -0
- package/tsconfig.build.json +5 -0
- package/tsconfig.cjs.json +8 -0
- package/tsconfig.esm.json +7 -0
- package/tsconfig.json +42 -0
- package/vitest.config.ts +41 -0
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
import {
|
|
2
|
+
getOauthEndpoints,
|
|
3
|
+
getIssuerVariations,
|
|
4
|
+
displayModeFromState,
|
|
5
|
+
generateState,
|
|
6
|
+
} from "@/lib/oauth.js";
|
|
7
|
+
import { describe, it, expect, vi, beforeEach, afterEach } from "vitest";
|
|
8
|
+
import { oauthWellKnownResponse } from "../../support/fixtures.js";
|
|
9
|
+
|
|
10
|
+
describe("getOauthEndpoints", () => {
|
|
11
|
+
afterEach(vi.clearAllMocks);
|
|
12
|
+
|
|
13
|
+
beforeEach(() => {
|
|
14
|
+
global.fetch = vi.fn().mockResolvedValue({
|
|
15
|
+
json: vi.fn().mockResolvedValue(oauthWellKnownResponse),
|
|
16
|
+
});
|
|
17
|
+
});
|
|
18
|
+
|
|
19
|
+
it("should translate the response from the auth server into an endpoints object", async () => {
|
|
20
|
+
const response = await getOauthEndpoints("https://example.com");
|
|
21
|
+
expect(response).toEqual({
|
|
22
|
+
auth: "https://auth-dev.civic.com/oauth/auth",
|
|
23
|
+
token: "https://auth-dev.civic.com/oauth/token",
|
|
24
|
+
jwks: "https://auth-dev.civic.com/oauth/jwks",
|
|
25
|
+
userinfo: "https://auth-dev.civic.com/oauth/me",
|
|
26
|
+
});
|
|
27
|
+
});
|
|
28
|
+
});
|
|
29
|
+
|
|
30
|
+
describe("getIssuerVariations", () => {
|
|
31
|
+
it("should return an array of variations of the issuer", () => {
|
|
32
|
+
const issuer = "https://example.com";
|
|
33
|
+
const variations = getIssuerVariations(issuer);
|
|
34
|
+
expect(variations).toEqual(["https://example.com", "https://example.com/"]);
|
|
35
|
+
});
|
|
36
|
+
});
|
|
37
|
+
|
|
38
|
+
describe("displayModeFromState", () => {
|
|
39
|
+
it("should return the display mode from the state", () => {
|
|
40
|
+
const state = "state";
|
|
41
|
+
const displayMode = "redirect";
|
|
42
|
+
const result = displayModeFromState(state, displayMode);
|
|
43
|
+
|
|
44
|
+
expect(result).toEqual(displayMode);
|
|
45
|
+
});
|
|
46
|
+
|
|
47
|
+
it("should extract the display mode correctly from state", () => {
|
|
48
|
+
const state =
|
|
49
|
+
"eyJ1dWlkIjoiMGY0NWU5YWItY2U1Ni00OWZiLTlkYmUtOGQ3ZmM3YTI3NDFhIiwiZGlzcGxheU1vZGUiOiJpZnJhbWUiLCJzZXJ2ZXJUb2tlbkV4Y2hhbmdlIjp0cnVlfQ";
|
|
50
|
+
const displayMode = "redirect";
|
|
51
|
+
const result = displayModeFromState(state, displayMode);
|
|
52
|
+
|
|
53
|
+
expect(result).toEqual("iframe");
|
|
54
|
+
});
|
|
55
|
+
});
|
|
56
|
+
|
|
57
|
+
describe("generateState", () => {
|
|
58
|
+
it("should generate a state string", () => {
|
|
59
|
+
const state = generateState("redirect");
|
|
60
|
+
|
|
61
|
+
expect(state).toBeTruthy();
|
|
62
|
+
expect(state).toHaveLength(96);
|
|
63
|
+
});
|
|
64
|
+
|
|
65
|
+
it('should generate a state string with "serverTokenExchange" key', () => {
|
|
66
|
+
const state = generateState("redirect", true);
|
|
67
|
+
|
|
68
|
+
expect(state).toBeTruthy();
|
|
69
|
+
const decoded = atob(state);
|
|
70
|
+
expect(JSON.parse(decoded)).toHaveProperty("serverTokenExchange", true);
|
|
71
|
+
});
|
|
72
|
+
});
|
|
@@ -0,0 +1,175 @@
|
|
|
1
|
+
import { describe, it, expect, beforeEach, vi } from "vitest";
|
|
2
|
+
import debug from "debug";
|
|
3
|
+
import { createLogger } from "../../src/lib/logger";
|
|
4
|
+
|
|
5
|
+
// Mock the debug package
|
|
6
|
+
vi.mock("debug", () => {
|
|
7
|
+
const debugInstance = vi.fn();
|
|
8
|
+
const debug = vi.fn(() => debugInstance);
|
|
9
|
+
// Add color property to match debug package API
|
|
10
|
+
Object.defineProperty(debugInstance, "color", {
|
|
11
|
+
set: vi.fn(),
|
|
12
|
+
get: vi.fn(),
|
|
13
|
+
});
|
|
14
|
+
return { default: debug };
|
|
15
|
+
});
|
|
16
|
+
|
|
17
|
+
describe("Logger", () => {
|
|
18
|
+
let mockDebug: ReturnType<typeof debug>;
|
|
19
|
+
let debugInstance: ReturnType<typeof vi.fn>;
|
|
20
|
+
let logger: ReturnType<typeof createLogger>;
|
|
21
|
+
|
|
22
|
+
beforeEach(() => {
|
|
23
|
+
vi.clearAllMocks();
|
|
24
|
+
mockDebug = debug as unknown as ReturnType<typeof debug>;
|
|
25
|
+
debugInstance = mockDebug("test") as unknown as ReturnType<typeof vi.fn>;
|
|
26
|
+
logger = createLogger("test");
|
|
27
|
+
});
|
|
28
|
+
|
|
29
|
+
it("should create debug instances with correct namespaces", () => {
|
|
30
|
+
logger = createLogger("api:routes");
|
|
31
|
+
|
|
32
|
+
// Verify that debug was called with the correct namespaces
|
|
33
|
+
expect(mockDebug).toHaveBeenCalledWith("@civic/auth:api:routes:debug");
|
|
34
|
+
expect(mockDebug).toHaveBeenCalledWith("@civic/auth:api:routes:info");
|
|
35
|
+
expect(mockDebug).toHaveBeenCalledWith("@civic/auth:api:routes:warn");
|
|
36
|
+
expect(mockDebug).toHaveBeenCalledWith("@civic/auth:api:routes:error");
|
|
37
|
+
});
|
|
38
|
+
|
|
39
|
+
it("should log debug messages with context", () => {
|
|
40
|
+
const context = { requestId: "123", userId: "456" };
|
|
41
|
+
logger.debug("Processing request", context);
|
|
42
|
+
|
|
43
|
+
expect(debugInstance).toHaveBeenCalledWith("Processing request", context);
|
|
44
|
+
});
|
|
45
|
+
|
|
46
|
+
it("should log info messages with multiple arguments", () => {
|
|
47
|
+
const requestId = "123";
|
|
48
|
+
const duration = 456;
|
|
49
|
+
logger.info("Request completed", { requestId, duration });
|
|
50
|
+
|
|
51
|
+
expect(debugInstance).toHaveBeenCalledWith("Request completed", {
|
|
52
|
+
requestId,
|
|
53
|
+
duration,
|
|
54
|
+
});
|
|
55
|
+
});
|
|
56
|
+
|
|
57
|
+
it("should log warning messages with structured data", () => {
|
|
58
|
+
const warning = {
|
|
59
|
+
code: "RATE_LIMIT",
|
|
60
|
+
requestId: "123",
|
|
61
|
+
limit: 100,
|
|
62
|
+
current: 95,
|
|
63
|
+
};
|
|
64
|
+
|
|
65
|
+
logger.warn("Rate limit approaching", warning);
|
|
66
|
+
|
|
67
|
+
expect(debugInstance).toHaveBeenCalledWith(
|
|
68
|
+
"Rate limit approaching",
|
|
69
|
+
warning,
|
|
70
|
+
);
|
|
71
|
+
});
|
|
72
|
+
|
|
73
|
+
it("should log error messages with error objects", () => {
|
|
74
|
+
const error = new Error("Database connection failed");
|
|
75
|
+
const context = {
|
|
76
|
+
requestId: "123",
|
|
77
|
+
operation: "getUserProfile",
|
|
78
|
+
};
|
|
79
|
+
|
|
80
|
+
logger.error("Operation failed", { error, ...context });
|
|
81
|
+
|
|
82
|
+
expect(debugInstance).toHaveBeenCalledWith("Operation failed", {
|
|
83
|
+
error,
|
|
84
|
+
...context,
|
|
85
|
+
});
|
|
86
|
+
});
|
|
87
|
+
|
|
88
|
+
it("should handle undefined arguments", () => {
|
|
89
|
+
logger.info("Simple message");
|
|
90
|
+
|
|
91
|
+
expect(debugInstance).toHaveBeenCalledWith("Simple message");
|
|
92
|
+
});
|
|
93
|
+
|
|
94
|
+
it("should handle null values in context", () => {
|
|
95
|
+
const context = {
|
|
96
|
+
userId: null,
|
|
97
|
+
sessionId: undefined,
|
|
98
|
+
requestId: "123",
|
|
99
|
+
};
|
|
100
|
+
|
|
101
|
+
logger.debug("User context", context);
|
|
102
|
+
|
|
103
|
+
expect(debugInstance).toHaveBeenCalledWith("User context", context);
|
|
104
|
+
});
|
|
105
|
+
|
|
106
|
+
// Testing different logger namespaces
|
|
107
|
+
describe("Logger namespaces", () => {
|
|
108
|
+
it("should create db logger with correct namespace", () => {
|
|
109
|
+
const dbLogger = createLogger("api:db");
|
|
110
|
+
dbLogger.info("DB Operation");
|
|
111
|
+
|
|
112
|
+
expect(mockDebug).toHaveBeenCalledWith("@civic/auth:api:db:info");
|
|
113
|
+
});
|
|
114
|
+
|
|
115
|
+
it("should create auth handler logger with correct namespace", () => {
|
|
116
|
+
const authLogger = createLogger("api:handlers:auth");
|
|
117
|
+
authLogger.debug("Auth check");
|
|
118
|
+
|
|
119
|
+
expect(mockDebug).toHaveBeenCalledWith(
|
|
120
|
+
"@civic/auth:api:handlers:auth:debug",
|
|
121
|
+
);
|
|
122
|
+
});
|
|
123
|
+
});
|
|
124
|
+
|
|
125
|
+
// Integration-style tests
|
|
126
|
+
describe("Real-world scenarios", () => {
|
|
127
|
+
it("should log complete request lifecycle", () => {
|
|
128
|
+
const requestLogger = createLogger("api:request");
|
|
129
|
+
const requestId = "123";
|
|
130
|
+
const start = Date.now();
|
|
131
|
+
|
|
132
|
+
requestLogger.debug("Request started", {
|
|
133
|
+
requestId,
|
|
134
|
+
method: "GET",
|
|
135
|
+
path: "/api/users",
|
|
136
|
+
});
|
|
137
|
+
requestLogger.info("Processing request", { requestId, userId: "456" });
|
|
138
|
+
requestLogger.debug("DB query executed", { requestId, duration: 50 });
|
|
139
|
+
requestLogger.info("Request completed", {
|
|
140
|
+
requestId,
|
|
141
|
+
duration: Date.now() - start,
|
|
142
|
+
status: 200,
|
|
143
|
+
});
|
|
144
|
+
|
|
145
|
+
expect(debugInstance).toHaveBeenCalledTimes(4);
|
|
146
|
+
});
|
|
147
|
+
|
|
148
|
+
it("should log error scenario with full context", () => {
|
|
149
|
+
const requestLogger = createLogger("api:request");
|
|
150
|
+
const requestId = "123";
|
|
151
|
+
const error = new Error("Invalid user input");
|
|
152
|
+
const context = {
|
|
153
|
+
userId: "456",
|
|
154
|
+
input: { email: "invalid" },
|
|
155
|
+
validation: { failed: true, errors: ["Invalid email format"] },
|
|
156
|
+
};
|
|
157
|
+
|
|
158
|
+
requestLogger.debug("Validating input", {
|
|
159
|
+
requestId,
|
|
160
|
+
input: context.input,
|
|
161
|
+
});
|
|
162
|
+
requestLogger.warn("Validation failed", {
|
|
163
|
+
requestId,
|
|
164
|
+
validation: context.validation,
|
|
165
|
+
});
|
|
166
|
+
requestLogger.error("Request failed", {
|
|
167
|
+
requestId,
|
|
168
|
+
error,
|
|
169
|
+
context,
|
|
170
|
+
});
|
|
171
|
+
|
|
172
|
+
expect(debugInstance).toHaveBeenCalledTimes(3);
|
|
173
|
+
});
|
|
174
|
+
});
|
|
175
|
+
});
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { render } from "@testing-library/react";
|
|
2
|
+
import { describe, it, vi, expect } from "vitest";
|
|
3
|
+
import { CivicNextAuthProvider } from "@/nextjs/providers/NextAuthProvider.js";
|
|
4
|
+
import { resolveAuthConfig } from "@/nextjs/config.js";
|
|
5
|
+
import React from "react";
|
|
6
|
+
|
|
7
|
+
vi.mock("@/nextjs/config.js", () => ({
|
|
8
|
+
resolveAuthConfig: vi.fn(() => ({
|
|
9
|
+
clientId: "test-client-id",
|
|
10
|
+
oauthServer: "https://example.com",
|
|
11
|
+
callbackUrl: "https://example.com/callback",
|
|
12
|
+
challengeUrl: "https://example.com/challenge",
|
|
13
|
+
logoutUrl: "https://example.com/logout",
|
|
14
|
+
})),
|
|
15
|
+
}));
|
|
16
|
+
|
|
17
|
+
vi.mock("@/nextjs/hooks/useUserCookie", () => ({
|
|
18
|
+
useUserCookie: vi.fn(),
|
|
19
|
+
}));
|
|
20
|
+
|
|
21
|
+
vi.mock("@/nextjs/hooks/useTokenCookie", () => ({
|
|
22
|
+
useTokenCookie: vi.fn(),
|
|
23
|
+
}));
|
|
24
|
+
|
|
25
|
+
describe("CivicNextAuthProvider", () => {
|
|
26
|
+
it("should call resolveAuthConfig with no arguments", () => {
|
|
27
|
+
const children = <div>Test Content</div>;
|
|
28
|
+
|
|
29
|
+
render(
|
|
30
|
+
<CivicNextAuthProvider>
|
|
31
|
+
{children}
|
|
32
|
+
</CivicNextAuthProvider>
|
|
33
|
+
);
|
|
34
|
+
|
|
35
|
+
// The Next implementation should take all config from the next.config.js file, no config taken from provider props.
|
|
36
|
+
expect(resolveAuthConfig).toHaveBeenCalledWith();
|
|
37
|
+
});
|
|
38
|
+
});
|
|
@@ -0,0 +1,201 @@
|
|
|
1
|
+
/* eslint-disable turbo/no-undeclared-env-vars */
|
|
2
|
+
import { describe, it, expect, beforeEach, afterEach, vi } from "vitest";
|
|
3
|
+
import {
|
|
4
|
+
resolveAuthConfig,
|
|
5
|
+
createCivicAuthPlugin,
|
|
6
|
+
type AuthConfig,
|
|
7
|
+
defaultAuthConfig,
|
|
8
|
+
} from "@/nextjs/config.js";
|
|
9
|
+
import { TokensCookieConfig } from "@/index.js";
|
|
10
|
+
import { DEFAULT_AUTH_SERVER } from "@/constants.js";
|
|
11
|
+
|
|
12
|
+
const defaultCookies = {
|
|
13
|
+
id_token: {
|
|
14
|
+
httpOnly: true,
|
|
15
|
+
path: "/",
|
|
16
|
+
sameSite: "strict",
|
|
17
|
+
secure: true,
|
|
18
|
+
},
|
|
19
|
+
access_token: {
|
|
20
|
+
httpOnly: true,
|
|
21
|
+
path: "/",
|
|
22
|
+
sameSite: "strict",
|
|
23
|
+
secure: true,
|
|
24
|
+
},
|
|
25
|
+
refresh_token: {
|
|
26
|
+
httpOnly: true,
|
|
27
|
+
path: "/",
|
|
28
|
+
sameSite: "strict",
|
|
29
|
+
secure: true,
|
|
30
|
+
},
|
|
31
|
+
code_verifier: {
|
|
32
|
+
httpOnly: true,
|
|
33
|
+
path: "/",
|
|
34
|
+
sameSite: "strict",
|
|
35
|
+
secure: true,
|
|
36
|
+
},
|
|
37
|
+
} as TokensCookieConfig;
|
|
38
|
+
describe("nextjs/config", () => {
|
|
39
|
+
const originalEnv = process.env;
|
|
40
|
+
|
|
41
|
+
beforeEach(() => {
|
|
42
|
+
vi.resetModules();
|
|
43
|
+
process.env = { ...originalEnv };
|
|
44
|
+
});
|
|
45
|
+
|
|
46
|
+
afterEach(() => {
|
|
47
|
+
process.env = originalEnv;
|
|
48
|
+
vi.restoreAllMocks();
|
|
49
|
+
});
|
|
50
|
+
|
|
51
|
+
describe("resolveAuthConfig", () => {
|
|
52
|
+
it("should throw an error if clientId is not provided", () => {
|
|
53
|
+
expect(() => resolveAuthConfig()).toThrowError(
|
|
54
|
+
"Civic Auth client ID is required",
|
|
55
|
+
);
|
|
56
|
+
});
|
|
57
|
+
|
|
58
|
+
it("should use default values when no config is provided", () => {
|
|
59
|
+
// client id must be defined
|
|
60
|
+
process.env._civic_auth_client_id = "clientId";
|
|
61
|
+
const result = resolveAuthConfig();
|
|
62
|
+
expect(result).toEqual({ ...defaultAuthConfig, clientId: "clientId" });
|
|
63
|
+
});
|
|
64
|
+
|
|
65
|
+
it("should override default values with provided config", () => {
|
|
66
|
+
const config: AuthConfig = {
|
|
67
|
+
clientId: "clientId",
|
|
68
|
+
callbackUrl: "/custom/callback",
|
|
69
|
+
loginUrl: "/custom/login",
|
|
70
|
+
include: ["/protected/*"],
|
|
71
|
+
exclude: ["/public/*"],
|
|
72
|
+
};
|
|
73
|
+
const result = resolveAuthConfig(config);
|
|
74
|
+
expect(result.callbackUrl).toBe("/custom/callback");
|
|
75
|
+
expect(result.loginUrl).toBe("/custom/login");
|
|
76
|
+
expect(result.include).toEqual(["/protected/*"]);
|
|
77
|
+
expect(result.exclude).toEqual(["/public/*"]);
|
|
78
|
+
});
|
|
79
|
+
|
|
80
|
+
it("should use environment variables if set", () => {
|
|
81
|
+
process.env._civic_auth_client_id = "clientId";
|
|
82
|
+
process.env._civic_auth_callback_url = "/env/callback";
|
|
83
|
+
process.env._civic_auth_login_url = "/env/login";
|
|
84
|
+
process.env._civic_auth_includes = "/env/protected/*";
|
|
85
|
+
process.env._civic_auth_excludes = "/env/public/*";
|
|
86
|
+
|
|
87
|
+
const result = resolveAuthConfig();
|
|
88
|
+
expect(result.callbackUrl).toBe("/env/callback");
|
|
89
|
+
expect(result.loginUrl).toBe("/env/login");
|
|
90
|
+
expect(result.include).toEqual(["/env/protected/*"]);
|
|
91
|
+
expect(result.exclude).toEqual(["/env/public/*"]);
|
|
92
|
+
});
|
|
93
|
+
|
|
94
|
+
it("should prioritize provided config over environment variables", () => {
|
|
95
|
+
process.env._civic_auth_callback_url = "/env/callback";
|
|
96
|
+
const config: AuthConfig = {
|
|
97
|
+
clientId: "clientId",
|
|
98
|
+
callbackUrl: "/config/callback",
|
|
99
|
+
};
|
|
100
|
+
|
|
101
|
+
const result = resolveAuthConfig(config);
|
|
102
|
+
expect(result.callbackUrl).toBe("/config/callback");
|
|
103
|
+
});
|
|
104
|
+
|
|
105
|
+
it("should merge cookie configurations correctly", () => {
|
|
106
|
+
const config: AuthConfig = {
|
|
107
|
+
clientId: "clientId",
|
|
108
|
+
cookies: {
|
|
109
|
+
tokens: {
|
|
110
|
+
id_token: { ...defaultCookies.id_token, secure: false },
|
|
111
|
+
} as TokensCookieConfig,
|
|
112
|
+
user: {
|
|
113
|
+
httpOnly: false,
|
|
114
|
+
secure: false,
|
|
115
|
+
sameSite: "strict",
|
|
116
|
+
},
|
|
117
|
+
},
|
|
118
|
+
};
|
|
119
|
+
|
|
120
|
+
const result = resolveAuthConfig(config);
|
|
121
|
+
expect(result.cookies.tokens).toEqual({
|
|
122
|
+
...defaultCookies,
|
|
123
|
+
id_token: { ...defaultCookies.id_token, secure: false },
|
|
124
|
+
});
|
|
125
|
+
|
|
126
|
+
expect(result.cookies.user).toEqual({
|
|
127
|
+
httpOnly: false,
|
|
128
|
+
secure: false,
|
|
129
|
+
sameSite: "strict",
|
|
130
|
+
path: "/",
|
|
131
|
+
maxAge: 3600,
|
|
132
|
+
});
|
|
133
|
+
});
|
|
134
|
+
});
|
|
135
|
+
|
|
136
|
+
describe("createCivicAuthPlugin", () => {
|
|
137
|
+
it("should return a function", () => {
|
|
138
|
+
const plugin = createCivicAuthPlugin({ clientId: "clientId" });
|
|
139
|
+
expect(typeof plugin).toBe("function");
|
|
140
|
+
});
|
|
141
|
+
|
|
142
|
+
it("should set environment variables based on resolved config", () => {
|
|
143
|
+
const config = {
|
|
144
|
+
clientId: "clientId",
|
|
145
|
+
callbackUrl: "/custom/callback",
|
|
146
|
+
loginUrl: "/custom/login",
|
|
147
|
+
logoutUrl: "/custom/logout",
|
|
148
|
+
include: ["/protected/*"],
|
|
149
|
+
exclude: ["/public/*"],
|
|
150
|
+
cookies: {
|
|
151
|
+
tokens: defaultCookies,
|
|
152
|
+
user: {
|
|
153
|
+
secure: false,
|
|
154
|
+
sameSite: "strict",
|
|
155
|
+
maxAge: 3600,
|
|
156
|
+
} as const,
|
|
157
|
+
},
|
|
158
|
+
};
|
|
159
|
+
|
|
160
|
+
const plugin = createCivicAuthPlugin(config);
|
|
161
|
+
const nextConfig = plugin({});
|
|
162
|
+
|
|
163
|
+
expect(nextConfig.env).toEqual({
|
|
164
|
+
_civic_auth_client_id: "clientId",
|
|
165
|
+
_civic_auth_callback_url: "/custom/callback",
|
|
166
|
+
_civic_auth_challenge_url: "/api/auth/challenge",
|
|
167
|
+
_civic_auth_login_url: "/custom/login",
|
|
168
|
+
_civic_auth_logout_url: "/custom/logout",
|
|
169
|
+
_civic_auth_includes: "/protected/*",
|
|
170
|
+
_civic_auth_excludes: "/public/*",
|
|
171
|
+
_civic_oauth_server: DEFAULT_AUTH_SERVER,
|
|
172
|
+
_civic_auth_cookie_config: JSON.stringify({
|
|
173
|
+
tokens: defaultCookies,
|
|
174
|
+
user: {
|
|
175
|
+
secure: false,
|
|
176
|
+
httpOnly: false,
|
|
177
|
+
sameSite: "strict",
|
|
178
|
+
path: "/",
|
|
179
|
+
maxAge: 3600,
|
|
180
|
+
},
|
|
181
|
+
}),
|
|
182
|
+
});
|
|
183
|
+
});
|
|
184
|
+
|
|
185
|
+
it("should merge with existing Next.js config", () => {
|
|
186
|
+
const existingConfig = {
|
|
187
|
+
reactStrictMode: true,
|
|
188
|
+
env: {
|
|
189
|
+
CUSTOM_VAR: "value",
|
|
190
|
+
},
|
|
191
|
+
};
|
|
192
|
+
|
|
193
|
+
const plugin = createCivicAuthPlugin({ clientId: "clientId" });
|
|
194
|
+
const nextConfig = plugin(existingConfig);
|
|
195
|
+
|
|
196
|
+
expect(nextConfig.reactStrictMode).toBe(true);
|
|
197
|
+
expect(nextConfig.env).toHaveProperty("CUSTOM_VAR", "value");
|
|
198
|
+
expect(nextConfig.env).toHaveProperty("_civic_auth_callback_url");
|
|
199
|
+
});
|
|
200
|
+
});
|
|
201
|
+
});
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { describe, it, expect, beforeEach, vi } from "vitest";
|
|
2
|
+
import { GenericUserSession } from "@/shared/lib/UserSession.js";
|
|
3
|
+
import type { User } from "@/types.ts";
|
|
4
|
+
import { getUser } from "@/nextjs/index.js";
|
|
5
|
+
import { NextjsClientStorage } from "@/nextjs/cookies.js";
|
|
6
|
+
|
|
7
|
+
const mockUser: User = {
|
|
8
|
+
id: "user123",
|
|
9
|
+
name: "John Doe",
|
|
10
|
+
email: "john@example.com",
|
|
11
|
+
picture: "https://example.com/john.jpg",
|
|
12
|
+
idToken: "test-id-token",
|
|
13
|
+
accessToken: "test-access-token",
|
|
14
|
+
refreshToken: "test-refresh-token",
|
|
15
|
+
} as unknown as User;
|
|
16
|
+
|
|
17
|
+
describe("getUser", () => {
|
|
18
|
+
beforeEach(() => {
|
|
19
|
+
vi.clearAllMocks();
|
|
20
|
+
vi.spyOn(GenericUserSession.prototype, "get").mockReturnValue(mockUser);
|
|
21
|
+
vi.spyOn(NextjsClientStorage.prototype, "get").mockImplementation(
|
|
22
|
+
(cookieName: string) => {
|
|
23
|
+
switch (cookieName) {
|
|
24
|
+
case "access_token":
|
|
25
|
+
return "test-access-token";
|
|
26
|
+
case "id_token":
|
|
27
|
+
return "test-id-token";
|
|
28
|
+
case "refresh_token":
|
|
29
|
+
return "test-refresh-token";
|
|
30
|
+
default:
|
|
31
|
+
return null;
|
|
32
|
+
}
|
|
33
|
+
},
|
|
34
|
+
);
|
|
35
|
+
});
|
|
36
|
+
|
|
37
|
+
it("should get the user from session", () => {
|
|
38
|
+
const user = getUser();
|
|
39
|
+
expect(user).toEqual(mockUser);
|
|
40
|
+
});
|
|
41
|
+
});
|
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
import { describe, it, expect, beforeEach, vi } from "vitest";
|
|
2
|
+
import { NextResponse, type NextRequest } from "next/server.js";
|
|
3
|
+
import { authMiddleware, withAuth } from "@/nextjs/middleware/index.js";
|
|
4
|
+
import { defaultAuthConfig } from "@/nextjs/config.js";
|
|
5
|
+
|
|
6
|
+
// Mock next/server
|
|
7
|
+
vi.mock("next/server.js", () => ({
|
|
8
|
+
NextResponse: {
|
|
9
|
+
next: vi.fn(() => ({ type: "next" })),
|
|
10
|
+
redirect: vi.fn((url) => ({ type: "redirect", url })),
|
|
11
|
+
},
|
|
12
|
+
}));
|
|
13
|
+
|
|
14
|
+
describe("Auth Middleware", () => {
|
|
15
|
+
let request: NextRequest;
|
|
16
|
+
|
|
17
|
+
beforeEach(() => {
|
|
18
|
+
// Reset mocks
|
|
19
|
+
vi.clearAllMocks();
|
|
20
|
+
|
|
21
|
+
// Create base request
|
|
22
|
+
request = {
|
|
23
|
+
nextUrl: {
|
|
24
|
+
pathname: "/protected",
|
|
25
|
+
},
|
|
26
|
+
cookies: {
|
|
27
|
+
get: vi.fn(),
|
|
28
|
+
},
|
|
29
|
+
method: "GET",
|
|
30
|
+
url: "http://example.com/protected",
|
|
31
|
+
} as unknown as NextRequest;
|
|
32
|
+
|
|
33
|
+
process.env._civic_auth_client_id = "abc";
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
describe("authMiddleware", () => {
|
|
37
|
+
/* FIXME
|
|
38
|
+
it("should redirect to login when no token present", async () => {
|
|
39
|
+
const middleware = authMiddleware();
|
|
40
|
+
const response = await middleware(request);
|
|
41
|
+
|
|
42
|
+
expect(NextResponse.redirect).toHaveBeenCalledWith("http://example.com/");
|
|
43
|
+
expect(response.type).toBe("redirect");
|
|
44
|
+
});
|
|
45
|
+
*/
|
|
46
|
+
|
|
47
|
+
it("should allow access when token is present", async () => {
|
|
48
|
+
request.cookies.get = vi.fn().mockReturnValue({ value: "valid-token" });
|
|
49
|
+
const middleware = authMiddleware();
|
|
50
|
+
const response = await middleware(request);
|
|
51
|
+
|
|
52
|
+
expect(NextResponse.next).toHaveBeenCalled();
|
|
53
|
+
expect(response.type).toBe("next");
|
|
54
|
+
});
|
|
55
|
+
|
|
56
|
+
it("should skip auth check for redirect to login page", async () => {
|
|
57
|
+
request.nextUrl.pathname = "/login";
|
|
58
|
+
const middleware = authMiddleware({
|
|
59
|
+
...defaultAuthConfig,
|
|
60
|
+
loginUrl: "/login",
|
|
61
|
+
});
|
|
62
|
+
const response = await middleware(request);
|
|
63
|
+
|
|
64
|
+
expect(NextResponse.next).toHaveBeenCalled();
|
|
65
|
+
expect(response.type).toBe("next");
|
|
66
|
+
});
|
|
67
|
+
|
|
68
|
+
it("should not skip auth check for non-GET to login page", async () => {
|
|
69
|
+
request.nextUrl.pathname = "/login";
|
|
70
|
+
const middleware = authMiddleware({
|
|
71
|
+
...defaultAuthConfig,
|
|
72
|
+
loginUrl: "/login",
|
|
73
|
+
});
|
|
74
|
+
const response = await middleware({
|
|
75
|
+
...request,
|
|
76
|
+
method: "POST",
|
|
77
|
+
} as NextRequest);
|
|
78
|
+
|
|
79
|
+
// should have redirected to the login page
|
|
80
|
+
expect(NextResponse.next).not.toHaveBeenCalled();
|
|
81
|
+
expect(response.type).toBe("redirect");
|
|
82
|
+
});
|
|
83
|
+
});
|
|
84
|
+
|
|
85
|
+
describe("withAuth", () => {
|
|
86
|
+
it("should chain custom middleware when authenticated", async () => {
|
|
87
|
+
request.cookies.get = vi.fn().mockReturnValue({ value: "valid-token" });
|
|
88
|
+
const customMiddleware = vi.fn(() => NextResponse.next());
|
|
89
|
+
const middleware = withAuth(customMiddleware);
|
|
90
|
+
|
|
91
|
+
await middleware(request);
|
|
92
|
+
|
|
93
|
+
expect(customMiddleware).toHaveBeenCalled();
|
|
94
|
+
});
|
|
95
|
+
|
|
96
|
+
it("should not chain custom middleware when unauthorized", async () => {
|
|
97
|
+
const customMiddleware = vi.fn(() => NextResponse.next());
|
|
98
|
+
const middleware = withAuth(customMiddleware);
|
|
99
|
+
|
|
100
|
+
const response = await middleware(request);
|
|
101
|
+
|
|
102
|
+
expect(customMiddleware).not.toHaveBeenCalled();
|
|
103
|
+
expect(NextResponse.redirect).toHaveBeenCalled();
|
|
104
|
+
expect(response.type).toBe("redirect");
|
|
105
|
+
});
|
|
106
|
+
});
|
|
107
|
+
|
|
108
|
+
describe("path matching", () => {
|
|
109
|
+
it("should respect include patterns", async () => {
|
|
110
|
+
request.cookies.get = vi.fn().mockReturnValue({ value: "valid-token" });
|
|
111
|
+
request.nextUrl.pathname = "/public";
|
|
112
|
+
|
|
113
|
+
const middleware = authMiddleware({
|
|
114
|
+
include: ["/protected/**"],
|
|
115
|
+
});
|
|
116
|
+
|
|
117
|
+
const response = await middleware(request);
|
|
118
|
+
|
|
119
|
+
expect(NextResponse.next).toHaveBeenCalled();
|
|
120
|
+
expect(response.type).toBe("next");
|
|
121
|
+
});
|
|
122
|
+
|
|
123
|
+
it("should respect exclude patterns", async () => {
|
|
124
|
+
request.cookies.get = vi.fn().mockReturnValue({ value: "valid-token" });
|
|
125
|
+
request.nextUrl.pathname = "/protected/public";
|
|
126
|
+
|
|
127
|
+
const middleware = authMiddleware({
|
|
128
|
+
include: ["/protected/**"],
|
|
129
|
+
exclude: ["/protected/public"],
|
|
130
|
+
});
|
|
131
|
+
|
|
132
|
+
const response = await middleware(request);
|
|
133
|
+
|
|
134
|
+
expect(NextResponse.next).toHaveBeenCalled();
|
|
135
|
+
expect(response.type).toBe("next");
|
|
136
|
+
});
|
|
137
|
+
});
|
|
138
|
+
});
|