@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,179 @@
|
|
|
1
|
+
import { describe, it, expect, vi, beforeEach } from "vitest";
|
|
2
|
+
import {
|
|
3
|
+
resolveOAuthAccessCode,
|
|
4
|
+
isLoggedIn,
|
|
5
|
+
buildLoginUrl,
|
|
6
|
+
} from "@/server/login.js";
|
|
7
|
+
import { ServerAuthenticationResolver } from "@/server/ServerAuthenticationResolver.js";
|
|
8
|
+
import { GenericAuthenticationInitiator } from "@/services/AuthenticationService.js";
|
|
9
|
+
import { GenericPublicClientPKCEProducer } from "@/services/PKCE.js";
|
|
10
|
+
import { DEFAULT_AUTH_SERVER, DEFAULT_SCOPES } from "@/constants.js";
|
|
11
|
+
import type { OIDCTokenResponseBody, AuthStorage } from "@/types.js";
|
|
12
|
+
import type { AuthConfig } from "@/server/config.js";
|
|
13
|
+
import type { PKCEProducer } from "@/services/types.js";
|
|
14
|
+
|
|
15
|
+
vi.mock("@/server/ServerAuthenticationResolver");
|
|
16
|
+
vi.mock("@/services/AuthenticationService");
|
|
17
|
+
vi.mock("@/services/PKCE");
|
|
18
|
+
|
|
19
|
+
class StubPKCEProducer implements PKCEProducer {
|
|
20
|
+
constructor() {}
|
|
21
|
+
|
|
22
|
+
async getCodeChallenge(): Promise<string> {
|
|
23
|
+
return "dummyCodeChallenge";
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
async getCodeVerifier(): Promise<string> {
|
|
27
|
+
return "dummyCodeVerifier";
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
describe("Login Utilities", () => {
|
|
32
|
+
const mockAuthConfig: AuthConfig = {
|
|
33
|
+
clientId: "mockClientId",
|
|
34
|
+
oauthServer: "http://mockOauthServer",
|
|
35
|
+
redirectUrl: "http://localhost/redirect",
|
|
36
|
+
};
|
|
37
|
+
const mockTokens: OIDCTokenResponseBody = {
|
|
38
|
+
id_token: "mockIdToken",
|
|
39
|
+
access_token: "mockAccessToken",
|
|
40
|
+
refresh_token: "mockRefreshToken",
|
|
41
|
+
};
|
|
42
|
+
const mockStorage = {
|
|
43
|
+
get: vi.fn(),
|
|
44
|
+
set: vi.fn(),
|
|
45
|
+
} as unknown as AuthStorage;
|
|
46
|
+
|
|
47
|
+
describe("resolveOAuthAccessCode", () => {
|
|
48
|
+
it("should resolve the OAuth access code and return tokens", async () => {
|
|
49
|
+
vi.mocked(ServerAuthenticationResolver.build).mockResolvedValue({
|
|
50
|
+
tokenExchange: vi.fn().mockResolvedValue(mockTokens),
|
|
51
|
+
} as unknown as ServerAuthenticationResolver);
|
|
52
|
+
|
|
53
|
+
const result = await resolveOAuthAccessCode(
|
|
54
|
+
"mockCode",
|
|
55
|
+
"mockState",
|
|
56
|
+
mockStorage,
|
|
57
|
+
mockAuthConfig,
|
|
58
|
+
);
|
|
59
|
+
|
|
60
|
+
expect(ServerAuthenticationResolver.build).toHaveBeenCalledWith(
|
|
61
|
+
{
|
|
62
|
+
...mockAuthConfig,
|
|
63
|
+
oauthServer: mockAuthConfig.oauthServer ?? DEFAULT_AUTH_SERVER,
|
|
64
|
+
},
|
|
65
|
+
mockStorage,
|
|
66
|
+
undefined,
|
|
67
|
+
);
|
|
68
|
+
expect(result).toEqual(mockTokens);
|
|
69
|
+
});
|
|
70
|
+
});
|
|
71
|
+
|
|
72
|
+
describe("isLoggedIn", () => {
|
|
73
|
+
it("should return true if id_token is in storage", () => {
|
|
74
|
+
vi.mocked(mockStorage.get).mockReturnValue("mockIdToken");
|
|
75
|
+
|
|
76
|
+
const result = isLoggedIn(mockStorage);
|
|
77
|
+
|
|
78
|
+
expect(result).toBe(true);
|
|
79
|
+
});
|
|
80
|
+
|
|
81
|
+
it("should return false if id_token is not in storage", () => {
|
|
82
|
+
vi.mocked(mockStorage.get).mockReturnValue(null);
|
|
83
|
+
|
|
84
|
+
const result = isLoggedIn(mockStorage);
|
|
85
|
+
|
|
86
|
+
expect(result).toBe(false);
|
|
87
|
+
});
|
|
88
|
+
});
|
|
89
|
+
|
|
90
|
+
describe("buildLoginUrl", () => {
|
|
91
|
+
it("should generate a login URL with provided config", async () => {
|
|
92
|
+
const state = "mockState";
|
|
93
|
+
const scopes = ["openid", "profile"];
|
|
94
|
+
const pkceProducer = new StubPKCEProducer();
|
|
95
|
+
|
|
96
|
+
const authInitiator = new GenericAuthenticationInitiator({
|
|
97
|
+
...mockAuthConfig,
|
|
98
|
+
state,
|
|
99
|
+
scopes,
|
|
100
|
+
oauthServer: mockAuthConfig.oauthServer ?? DEFAULT_AUTH_SERVER,
|
|
101
|
+
pkceConsumer: pkceProducer,
|
|
102
|
+
});
|
|
103
|
+
vi.mocked(GenericAuthenticationInitiator).mockReturnValue(authInitiator);
|
|
104
|
+
vi.mocked(authInitiator.signIn).mockResolvedValue(
|
|
105
|
+
new URL("http://mockLoginUrl"),
|
|
106
|
+
);
|
|
107
|
+
|
|
108
|
+
const result = await buildLoginUrl(
|
|
109
|
+
{
|
|
110
|
+
...mockAuthConfig,
|
|
111
|
+
state,
|
|
112
|
+
scopes,
|
|
113
|
+
},
|
|
114
|
+
mockStorage,
|
|
115
|
+
);
|
|
116
|
+
|
|
117
|
+
expect(result.toString()).toBe("http://mockloginurl/");
|
|
118
|
+
expect(GenericAuthenticationInitiator).toHaveBeenCalledWith({
|
|
119
|
+
...mockAuthConfig,
|
|
120
|
+
state,
|
|
121
|
+
scopes,
|
|
122
|
+
oauthServer: mockAuthConfig.oauthServer ?? DEFAULT_AUTH_SERVER,
|
|
123
|
+
pkceConsumer: pkceProducer,
|
|
124
|
+
});
|
|
125
|
+
});
|
|
126
|
+
|
|
127
|
+
it("should generate a login URL with default state and scopes", async () => {
|
|
128
|
+
const authInitiator = new GenericAuthenticationInitiator({
|
|
129
|
+
...mockAuthConfig,
|
|
130
|
+
state: expect.any(String), // state is random if not provided
|
|
131
|
+
scopes: DEFAULT_SCOPES,
|
|
132
|
+
oauthServer: mockAuthConfig.oauthServer ?? DEFAULT_AUTH_SERVER,
|
|
133
|
+
pkceConsumer: expect.any(GenericPublicClientPKCEProducer),
|
|
134
|
+
});
|
|
135
|
+
vi.mocked(GenericAuthenticationInitiator).mockReturnValue(authInitiator);
|
|
136
|
+
vi.mocked(authInitiator.signIn).mockResolvedValue(
|
|
137
|
+
new URL("http://mockLoginUrl"),
|
|
138
|
+
);
|
|
139
|
+
|
|
140
|
+
const result = await buildLoginUrl(mockAuthConfig, mockStorage);
|
|
141
|
+
|
|
142
|
+
expect(result.toString()).toBe("http://mockloginurl/");
|
|
143
|
+
});
|
|
144
|
+
|
|
145
|
+
it("should include nonce in the login URL if provided in config", async () => {
|
|
146
|
+
const state = "mockState";
|
|
147
|
+
const scopes = ["openid", "profile"];
|
|
148
|
+
const nonce = "mockNonce";
|
|
149
|
+
const pkceProducer = new GenericPublicClientPKCEProducer(mockStorage);
|
|
150
|
+
|
|
151
|
+
const authInitiator = new GenericAuthenticationInitiator({
|
|
152
|
+
...mockAuthConfig,
|
|
153
|
+
state,
|
|
154
|
+
scopes,
|
|
155
|
+
oauthServer: mockAuthConfig.oauthServer ?? DEFAULT_AUTH_SERVER,
|
|
156
|
+
pkceConsumer: pkceProducer,
|
|
157
|
+
nonce,
|
|
158
|
+
});
|
|
159
|
+
vi.mocked(GenericAuthenticationInitiator).mockReturnValue(authInitiator);
|
|
160
|
+
vi.mocked(authInitiator.signIn).mockResolvedValue(
|
|
161
|
+
new URL(`http://mockLoginUrl?nonce=${nonce}`),
|
|
162
|
+
);
|
|
163
|
+
|
|
164
|
+
await buildLoginUrl(
|
|
165
|
+
{
|
|
166
|
+
...mockAuthConfig,
|
|
167
|
+
state,
|
|
168
|
+
scopes,
|
|
169
|
+
nonce,
|
|
170
|
+
},
|
|
171
|
+
mockStorage,
|
|
172
|
+
);
|
|
173
|
+
|
|
174
|
+
expect(GenericAuthenticationInitiator).toHaveBeenCalledWith(expect.objectContaining({
|
|
175
|
+
nonce,
|
|
176
|
+
}));
|
|
177
|
+
});
|
|
178
|
+
});
|
|
179
|
+
});
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { describe, it, expect, vi, beforeEach } from "vitest";
|
|
2
|
+
import type { JWT } from "oslo/jwt";
|
|
3
|
+
import { parseJWT } from "oslo/jwt";
|
|
4
|
+
import { getUser } from "@/shared/lib/session.js";
|
|
5
|
+
import { retrieveTokens } from "@/shared/lib/util.js";
|
|
6
|
+
import type { AuthStorage, OIDCTokenResponseBody, User } from "@/types.js";
|
|
7
|
+
|
|
8
|
+
vi.mock("@/shared/lib/util.js");
|
|
9
|
+
vi.mock("oslo/jwt");
|
|
10
|
+
|
|
11
|
+
describe("getUser", () => {
|
|
12
|
+
const mockStorage = {} as AuthStorage;
|
|
13
|
+
const mockUser: User = {
|
|
14
|
+
id: "mockUserId",
|
|
15
|
+
email: "user@example.com",
|
|
16
|
+
} as User;
|
|
17
|
+
|
|
18
|
+
beforeEach(() => {
|
|
19
|
+
vi.clearAllMocks();
|
|
20
|
+
});
|
|
21
|
+
|
|
22
|
+
it("should return null if no tokens are retrieved", async () => {
|
|
23
|
+
vi.mocked(retrieveTokens).mockReturnValue(null);
|
|
24
|
+
|
|
25
|
+
const result = await getUser(mockStorage);
|
|
26
|
+
expect(result).toBeNull();
|
|
27
|
+
expect(retrieveTokens).toHaveBeenCalledWith(mockStorage);
|
|
28
|
+
});
|
|
29
|
+
|
|
30
|
+
it("should return a User if tokens are retrieved and parsed successfully", async () => {
|
|
31
|
+
const mockTokens = { id_token: "mockIdToken" } as OIDCTokenResponseBody;
|
|
32
|
+
vi.mocked(retrieveTokens).mockReturnValue(mockTokens);
|
|
33
|
+
vi.mocked(parseJWT).mockReturnValue({ payload: mockUser } as JWT);
|
|
34
|
+
|
|
35
|
+
const result = await getUser(mockStorage);
|
|
36
|
+
expect(result).toEqual(mockUser);
|
|
37
|
+
expect(retrieveTokens).toHaveBeenCalledWith(mockStorage);
|
|
38
|
+
expect(parseJWT).toHaveBeenCalledWith(mockTokens.id_token);
|
|
39
|
+
});
|
|
40
|
+
|
|
41
|
+
it("should return null if parsing the ID token fails", async () => {
|
|
42
|
+
const mockTokens = { id_token: "mockIdToken" } as OIDCTokenResponseBody;
|
|
43
|
+
vi.mocked(retrieveTokens).mockReturnValue(mockTokens);
|
|
44
|
+
vi.mocked(parseJWT).mockReturnValue(null); // Simulate parse failure
|
|
45
|
+
|
|
46
|
+
const result = await getUser(mockStorage);
|
|
47
|
+
expect(result).toBeNull();
|
|
48
|
+
expect(retrieveTokens).toHaveBeenCalledWith(mockStorage);
|
|
49
|
+
expect(parseJWT).toHaveBeenCalledWith(mockTokens.id_token);
|
|
50
|
+
});
|
|
51
|
+
});
|
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
import { describe, it, expect, vi, beforeEach } from "vitest";
|
|
2
|
+
import {
|
|
3
|
+
BrowserAuthenticationInitiator,
|
|
4
|
+
BrowserAuthenticationService,
|
|
5
|
+
GenericAuthenticationInitiator,
|
|
6
|
+
} from "@/services/AuthenticationService.js";
|
|
7
|
+
import {
|
|
8
|
+
generateOauthLoginUrl,
|
|
9
|
+
generateOauthLogoutUrl,
|
|
10
|
+
exchangeTokens,
|
|
11
|
+
retrieveTokens,
|
|
12
|
+
storeTokens,
|
|
13
|
+
} from "@/shared/lib/util.js";
|
|
14
|
+
import { LocalStorageAdapter } from "@/browser/storage.js";
|
|
15
|
+
import { BrowserPublicClientPKCEProducer } from "@/services/PKCE.js";
|
|
16
|
+
import type { OIDCTokenResponseBody, SessionData } from "@/types.js";
|
|
17
|
+
import type { AuthenticationResolver, PKCEConsumer } from "@/services/types.js";
|
|
18
|
+
|
|
19
|
+
vi.mock("@/shared/lib/util.js", () => ({
|
|
20
|
+
getEndpointsWithOverrides: async () => ({
|
|
21
|
+
auth: "auth-endpoint",
|
|
22
|
+
}),
|
|
23
|
+
exchangeTokens: vi.fn(),
|
|
24
|
+
retrieveTokens: vi.fn(),
|
|
25
|
+
storeTokens: vi.fn(),
|
|
26
|
+
generateOauthLoginUrl: vi.fn(),
|
|
27
|
+
generateOauthLogoutUrl: vi.fn(),
|
|
28
|
+
clearTokens: vi.fn(),
|
|
29
|
+
clearUser: vi.fn(),
|
|
30
|
+
}));
|
|
31
|
+
vi.mock("@/browser/storage");
|
|
32
|
+
vi.mock("@/services/PKCE");
|
|
33
|
+
|
|
34
|
+
describe("Authentication Services", () => {
|
|
35
|
+
const mockConfig = {
|
|
36
|
+
clientId: "mockClientId",
|
|
37
|
+
redirectUrl: "http://localhost/redirect",
|
|
38
|
+
state: "mockState",
|
|
39
|
+
scopes: ["openid", "profile"],
|
|
40
|
+
displayMode: "redirect" as const,
|
|
41
|
+
oauthServer: "http://mockOauthServer",
|
|
42
|
+
};
|
|
43
|
+
|
|
44
|
+
describe("BrowserAuthenticationInitiator", () => {
|
|
45
|
+
it("should generate a login URL", async () => {
|
|
46
|
+
const initiator = new BrowserAuthenticationInitiator({
|
|
47
|
+
...mockConfig,
|
|
48
|
+
pkceConsumer: {} as PKCEConsumer,
|
|
49
|
+
});
|
|
50
|
+
vi.mocked(generateOauthLoginUrl).mockResolvedValue(
|
|
51
|
+
new URL("http://mockLoginUrl"),
|
|
52
|
+
);
|
|
53
|
+
|
|
54
|
+
const url = await initiator.signIn(null);
|
|
55
|
+
|
|
56
|
+
expect(url.toString()).toBe("http://mockloginurl/");
|
|
57
|
+
});
|
|
58
|
+
|
|
59
|
+
it("should generate a logout URL", async () => {
|
|
60
|
+
const initiator = new BrowserAuthenticationInitiator({
|
|
61
|
+
...mockConfig,
|
|
62
|
+
pkceConsumer: {} as PKCEConsumer,
|
|
63
|
+
});
|
|
64
|
+
vi.mocked(generateOauthLogoutUrl).mockResolvedValue(
|
|
65
|
+
new URL("http://mocklogouturl"),
|
|
66
|
+
);
|
|
67
|
+
|
|
68
|
+
const url = await initiator.signOut();
|
|
69
|
+
|
|
70
|
+
expect(url.toString()).toBe("http://mocklogouturl/");
|
|
71
|
+
});
|
|
72
|
+
});
|
|
73
|
+
|
|
74
|
+
describe("GenericAuthenticationInitiator", () => {
|
|
75
|
+
it("should generate a login URL", async () => {
|
|
76
|
+
const initiator = new GenericAuthenticationInitiator({
|
|
77
|
+
...mockConfig,
|
|
78
|
+
pkceConsumer: {} as PKCEConsumer,
|
|
79
|
+
});
|
|
80
|
+
vi.mocked(generateOauthLoginUrl).mockResolvedValue(
|
|
81
|
+
new URL("http://mockloginurl"),
|
|
82
|
+
);
|
|
83
|
+
|
|
84
|
+
const url = await initiator.signIn();
|
|
85
|
+
|
|
86
|
+
expect(url.toString()).toBe("http://mockloginurl/");
|
|
87
|
+
});
|
|
88
|
+
|
|
89
|
+
it("should generate a logout URL", async () => {
|
|
90
|
+
const initiator = new GenericAuthenticationInitiator({
|
|
91
|
+
...mockConfig,
|
|
92
|
+
pkceConsumer: {} as PKCEConsumer,
|
|
93
|
+
});
|
|
94
|
+
vi.mocked(generateOauthLogoutUrl).mockResolvedValue(
|
|
95
|
+
new URL("http://mocklogouturl"),
|
|
96
|
+
);
|
|
97
|
+
|
|
98
|
+
const url = await initiator.signOut();
|
|
99
|
+
|
|
100
|
+
expect(url.toString()).toBe("http://mocklogouturl/");
|
|
101
|
+
});
|
|
102
|
+
});
|
|
103
|
+
|
|
104
|
+
describe("BrowserAuthenticationService", () => {
|
|
105
|
+
let service: AuthenticationResolver;
|
|
106
|
+
const mockTokens: OIDCTokenResponseBody = {
|
|
107
|
+
id_token: "mockIdToken",
|
|
108
|
+
access_token: "mockAccessToken",
|
|
109
|
+
refresh_token: "mockRefreshToken",
|
|
110
|
+
};
|
|
111
|
+
|
|
112
|
+
beforeEach(async () => {
|
|
113
|
+
service = await BrowserAuthenticationService.build({
|
|
114
|
+
...mockConfig,
|
|
115
|
+
});
|
|
116
|
+
vi.mocked(exchangeTokens).mockResolvedValue(mockTokens);
|
|
117
|
+
vi.mocked(retrieveTokens).mockReturnValue(mockTokens);
|
|
118
|
+
});
|
|
119
|
+
|
|
120
|
+
it("should exchange auth code for tokens and store them", async () => {
|
|
121
|
+
const code = "mockCode";
|
|
122
|
+
const state = "mockState";
|
|
123
|
+
|
|
124
|
+
vi.mocked(
|
|
125
|
+
BrowserPublicClientPKCEProducer.prototype.getCodeVerifier,
|
|
126
|
+
).mockResolvedValue("dummy-verifier");
|
|
127
|
+
|
|
128
|
+
const tokens = await service.tokenExchange(code, state);
|
|
129
|
+
|
|
130
|
+
expect(storeTokens).toHaveBeenCalledWith(
|
|
131
|
+
expect.any(LocalStorageAdapter),
|
|
132
|
+
mockTokens,
|
|
133
|
+
);
|
|
134
|
+
expect(tokens).toEqual(mockTokens);
|
|
135
|
+
});
|
|
136
|
+
|
|
137
|
+
it("should retrieve session data from local storage", async () => {
|
|
138
|
+
const sessionData: SessionData = {
|
|
139
|
+
authenticated: true,
|
|
140
|
+
idToken: mockTokens.id_token,
|
|
141
|
+
accessToken: mockTokens.access_token,
|
|
142
|
+
refreshToken: mockTokens.refresh_token,
|
|
143
|
+
};
|
|
144
|
+
const result = await service.getSessionData();
|
|
145
|
+
|
|
146
|
+
expect(retrieveTokens).toHaveBeenCalledWith(
|
|
147
|
+
expect.any(LocalStorageAdapter),
|
|
148
|
+
);
|
|
149
|
+
expect(result).toEqual(sessionData);
|
|
150
|
+
});
|
|
151
|
+
});
|
|
152
|
+
});
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
import { describe, it, expect, vi, beforeEach } from "vitest";
|
|
2
|
+
import { ServerAuthenticationResolver } from "@/server/ServerAuthenticationResolver.js";
|
|
3
|
+
import {
|
|
4
|
+
exchangeTokens,
|
|
5
|
+
getEndpointsWithOverrides,
|
|
6
|
+
retrieveTokens,
|
|
7
|
+
storeTokens,
|
|
8
|
+
} from "@/shared/lib/util.js";
|
|
9
|
+
import type { Endpoints, OIDCTokenResponseBody, SessionData, AuthStorage } from "@/types.js";
|
|
10
|
+
import type { AuthConfig } from "@/server/config.js";
|
|
11
|
+
import { GenericPublicClientPKCEProducer } from "@/services/PKCE.js";
|
|
12
|
+
import type { AuthenticationResolver } from '@/services/types.js';
|
|
13
|
+
|
|
14
|
+
vi.mock("oslo/oauth2");
|
|
15
|
+
vi.mock("@/services/PKCE");
|
|
16
|
+
vi.mock("@/shared/lib/util.js");
|
|
17
|
+
|
|
18
|
+
describe("ServerAuthenticationResolver", () => {
|
|
19
|
+
const mockAuthConfig: AuthConfig = {
|
|
20
|
+
clientId: "mockClientId",
|
|
21
|
+
oauthServer: "http://mockOauthServer",
|
|
22
|
+
redirectUrl: "http://localhost/redirect",
|
|
23
|
+
challengeUrl: "http://localhost/challenge",
|
|
24
|
+
};
|
|
25
|
+
const mockEndpoints: Endpoints = {
|
|
26
|
+
auth: "http://mockAuthEndpoint",
|
|
27
|
+
token: "http://mockTokenEndpoint",
|
|
28
|
+
jwks: "http://mockJwksEndpoint",
|
|
29
|
+
userinfo: "http://mockUserinfoEndpoint",
|
|
30
|
+
};
|
|
31
|
+
const mockTokens: OIDCTokenResponseBody = {
|
|
32
|
+
id_token: "mockIdToken",
|
|
33
|
+
access_token: "mockAccessToken",
|
|
34
|
+
refresh_token: "mockRefreshToken",
|
|
35
|
+
};
|
|
36
|
+
const mockStorage = {} as AuthStorage;
|
|
37
|
+
|
|
38
|
+
let resolver: AuthenticationResolver;
|
|
39
|
+
|
|
40
|
+
beforeEach(async () => {
|
|
41
|
+
vi.clearAllMocks();
|
|
42
|
+
vi.mocked(getEndpointsWithOverrides).mockResolvedValue(mockEndpoints);
|
|
43
|
+
resolver = await ServerAuthenticationResolver.build(
|
|
44
|
+
mockAuthConfig,
|
|
45
|
+
mockStorage,
|
|
46
|
+
);
|
|
47
|
+
});
|
|
48
|
+
|
|
49
|
+
describe("init", () => {
|
|
50
|
+
it("should initialize OAuth2 client with resolved endpoints", async () => {
|
|
51
|
+
expect(getEndpointsWithOverrides).toHaveBeenCalledWith(
|
|
52
|
+
mockAuthConfig.oauthServer,
|
|
53
|
+
undefined,
|
|
54
|
+
);
|
|
55
|
+
});
|
|
56
|
+
});
|
|
57
|
+
|
|
58
|
+
describe("tokenExchange", () => {
|
|
59
|
+
it("should exchange auth code for tokens and store them", async () => {
|
|
60
|
+
const code = "mockCode";
|
|
61
|
+
const state = "mockState";
|
|
62
|
+
const codeVerifier = "mockCodeVerifier";
|
|
63
|
+
vi.mocked(
|
|
64
|
+
GenericPublicClientPKCEProducer.prototype.getCodeVerifier,
|
|
65
|
+
).mockResolvedValue(codeVerifier);
|
|
66
|
+
vi.mocked(exchangeTokens).mockResolvedValue(mockTokens);
|
|
67
|
+
|
|
68
|
+
const tokens = await resolver.tokenExchange(code, state);
|
|
69
|
+
|
|
70
|
+
expect(storeTokens).toHaveBeenCalledWith(mockStorage, mockTokens);
|
|
71
|
+
expect(tokens).toEqual(mockTokens);
|
|
72
|
+
});
|
|
73
|
+
|
|
74
|
+
it("should throw an error if code verifier is not found", async () => {
|
|
75
|
+
vi.mocked(
|
|
76
|
+
GenericPublicClientPKCEProducer.prototype.getCodeVerifier,
|
|
77
|
+
).mockResolvedValue(null);
|
|
78
|
+
|
|
79
|
+
await expect(
|
|
80
|
+
resolver.tokenExchange("mockCode", "mockState"),
|
|
81
|
+
).rejects.toThrow("Code verifier not found in storage");
|
|
82
|
+
});
|
|
83
|
+
});
|
|
84
|
+
|
|
85
|
+
describe("getSessionData", () => {
|
|
86
|
+
it("should retrieve session data from storage", async () => {
|
|
87
|
+
vi.mocked(retrieveTokens).mockReturnValue(mockTokens);
|
|
88
|
+
|
|
89
|
+
const sessionData: SessionData = {
|
|
90
|
+
authenticated: true,
|
|
91
|
+
idToken: mockTokens.id_token,
|
|
92
|
+
accessToken: mockTokens.access_token,
|
|
93
|
+
refreshToken: mockTokens.refresh_token,
|
|
94
|
+
};
|
|
95
|
+
|
|
96
|
+
const result = await resolver.getSessionData();
|
|
97
|
+
|
|
98
|
+
expect(retrieveTokens).toHaveBeenCalledWith(mockStorage);
|
|
99
|
+
expect(result).toEqual(sessionData);
|
|
100
|
+
});
|
|
101
|
+
|
|
102
|
+
it("should return null if no tokens are found in storage", async () => {
|
|
103
|
+
vi.mocked(retrieveTokens).mockReturnValue(null);
|
|
104
|
+
|
|
105
|
+
const result = await resolver.getSessionData();
|
|
106
|
+
|
|
107
|
+
expect(result).toBeNull();
|
|
108
|
+
});
|
|
109
|
+
});
|
|
110
|
+
});
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
import { describe, it, expect, vi, beforeEach } from "vitest";
|
|
2
|
+
import { GenericAuthenticationRefresher } from "@/shared/lib/GenericAuthenticationRefresher.js";
|
|
3
|
+
import {
|
|
4
|
+
getEndpointsWithOverrides,
|
|
5
|
+
retrieveTokens,
|
|
6
|
+
storeTokens,
|
|
7
|
+
} from "@/shared/lib/util.js";
|
|
8
|
+
import type { Endpoints, OIDCTokenResponseBody, AuthStorage} from "@/types.js";
|
|
9
|
+
import { OAuth2Client } from "oslo/oauth2";
|
|
10
|
+
import type { AuthConfig } from "@/server/config.js";
|
|
11
|
+
|
|
12
|
+
vi.mock("@/shared/lib/util.js");
|
|
13
|
+
vi.mock("oslo/oauth2");
|
|
14
|
+
|
|
15
|
+
describe("GenericAuthenticationRefresher", () => {
|
|
16
|
+
const mockAuthConfig: AuthConfig = {
|
|
17
|
+
clientId: "mockClientId",
|
|
18
|
+
oauthServer: "http://mockOauthServer",
|
|
19
|
+
redirectUrl: "http://localhost/redirect",
|
|
20
|
+
};
|
|
21
|
+
const mockEndpoints: Endpoints = {
|
|
22
|
+
auth: "http://mockAuthEndpoint",
|
|
23
|
+
token: "http://mockTokenEndpoint",
|
|
24
|
+
jwks: "http://mockJwksEndpoint",
|
|
25
|
+
userinfo: "http://mockUserinfoEndpoint",
|
|
26
|
+
};
|
|
27
|
+
const mockTokens: OIDCTokenResponseBody = {
|
|
28
|
+
id_token: "mockIdToken",
|
|
29
|
+
access_token: "mockAccessToken",
|
|
30
|
+
refresh_token: "mockRefreshToken",
|
|
31
|
+
};
|
|
32
|
+
const mockStorage = {} as AuthStorage;
|
|
33
|
+
|
|
34
|
+
let refresher: GenericAuthenticationRefresher;
|
|
35
|
+
|
|
36
|
+
beforeEach(async () => {
|
|
37
|
+
vi.clearAllMocks();
|
|
38
|
+
vi.mocked(getEndpointsWithOverrides).mockResolvedValue(mockEndpoints);
|
|
39
|
+
refresher = await GenericAuthenticationRefresher.build(
|
|
40
|
+
mockAuthConfig,
|
|
41
|
+
mockStorage,
|
|
42
|
+
);
|
|
43
|
+
});
|
|
44
|
+
|
|
45
|
+
describe("init", () => {
|
|
46
|
+
it("should initialize OAuth2 client with resolved endpoints", async () => {
|
|
47
|
+
expect(getEndpointsWithOverrides).toHaveBeenCalledWith(
|
|
48
|
+
mockAuthConfig.oauthServer,
|
|
49
|
+
undefined,
|
|
50
|
+
);
|
|
51
|
+
expect(refresher["endpoints"]).toEqual(mockEndpoints);
|
|
52
|
+
expect(refresher["oauth2client"]).toBeInstanceOf(OAuth2Client);
|
|
53
|
+
});
|
|
54
|
+
});
|
|
55
|
+
|
|
56
|
+
describe("refreshTokens", () => {
|
|
57
|
+
it("should refresh tokens and store them", async () => {
|
|
58
|
+
vi.mocked(retrieveTokens).mockReturnValue(mockTokens);
|
|
59
|
+
const refreshedTokens: OIDCTokenResponseBody = {
|
|
60
|
+
id_token: "newIdToken",
|
|
61
|
+
access_token: "newAccessToken",
|
|
62
|
+
refresh_token: "newRefreshToken",
|
|
63
|
+
};
|
|
64
|
+
|
|
65
|
+
vi.mocked(OAuth2Client.prototype.refreshAccessToken).mockResolvedValue(
|
|
66
|
+
refreshedTokens,
|
|
67
|
+
);
|
|
68
|
+
|
|
69
|
+
const result = await refresher.refreshTokens();
|
|
70
|
+
|
|
71
|
+
expect(
|
|
72
|
+
refresher["oauth2client"]?.refreshAccessToken,
|
|
73
|
+
).toHaveBeenCalledWith(mockTokens.refresh_token);
|
|
74
|
+
expect(storeTokens).toHaveBeenCalledWith(mockStorage, refreshedTokens);
|
|
75
|
+
expect(result).toEqual(mockTokens);
|
|
76
|
+
});
|
|
77
|
+
|
|
78
|
+
it("should throw an error if no refresh token is available", async () => {
|
|
79
|
+
vi.mocked(retrieveTokens).mockReturnValue({
|
|
80
|
+
...mockTokens,
|
|
81
|
+
refresh_token: undefined,
|
|
82
|
+
});
|
|
83
|
+
|
|
84
|
+
await expect(refresher.refreshTokens()).rejects.toThrow(
|
|
85
|
+
"No refresh token available",
|
|
86
|
+
);
|
|
87
|
+
});
|
|
88
|
+
});
|
|
89
|
+
});
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { describe, it, expect } from "vitest";
|
|
2
|
+
import { GenericUserSession } from "@/shared/lib/UserSession.js";
|
|
3
|
+
import type { AuthStorage, User } from "@/types.ts";
|
|
4
|
+
|
|
5
|
+
const mockUser: User = {
|
|
6
|
+
id: "user123",
|
|
7
|
+
name: "John Doe",
|
|
8
|
+
email: "john@example.com",
|
|
9
|
+
picture: "https://example.com/john.jpg",
|
|
10
|
+
forwardedTokens: null,
|
|
11
|
+
} as unknown as User;
|
|
12
|
+
|
|
13
|
+
let storage: Record<string, string> = {};
|
|
14
|
+
class TestStorage implements AuthStorage {
|
|
15
|
+
get(key: string): string | null {
|
|
16
|
+
return storage[key] ?? null;
|
|
17
|
+
}
|
|
18
|
+
set(key: string, value: string): void {
|
|
19
|
+
storage[key] = value;
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
describe("UserSession", () => {
|
|
24
|
+
beforeEach(() => {
|
|
25
|
+
storage = {}; // clear storage
|
|
26
|
+
});
|
|
27
|
+
|
|
28
|
+
describe("GenericUserSession", () => {
|
|
29
|
+
it("should get the user from session", () => {
|
|
30
|
+
const userSession = new GenericUserSession(new TestStorage());
|
|
31
|
+
userSession.set(mockUser);
|
|
32
|
+
const user = userSession.get();
|
|
33
|
+
expect(user).toEqual(mockUser);
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
it("should return null if user it not found", () => {
|
|
37
|
+
const userSession = new GenericUserSession(new TestStorage());
|
|
38
|
+
const user = userSession.get();
|
|
39
|
+
expect(user).toBeNull();
|
|
40
|
+
});
|
|
41
|
+
});
|
|
42
|
+
});
|