@civic/auth 0.3.5-temp-debug-logs.2 → 0.3.6-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +6 -0
- package/dist/browser/storage.d.ts.map +1 -0
- package/dist/browser/storage.js.map +1 -0
- package/dist/config.d.ts.map +1 -0
- package/dist/config.js.map +1 -0
- package/dist/constants.d.ts +15 -0
- package/dist/constants.d.ts.map +1 -0
- package/dist/constants.js +29 -0
- package/dist/constants.js.map +1 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js.map +1 -0
- package/dist/lib/cookies.d.ts.map +1 -0
- package/dist/lib/cookies.js.map +1 -0
- package/dist/lib/jwt.d.ts.map +1 -0
- package/dist/lib/jwt.js.map +1 -0
- package/dist/lib/logger.d.ts.map +1 -0
- package/dist/lib/logger.js.map +1 -0
- package/dist/lib/oauth.d.ts.map +1 -0
- package/dist/lib/oauth.js.map +1 -0
- package/dist/lib/obj.d.ts.map +1 -0
- package/dist/lib/obj.js.map +1 -0
- package/dist/lib/postMessage.d.ts.map +1 -0
- package/dist/lib/postMessage.js +13 -0
- package/dist/lib/postMessage.js.map +1 -0
- package/dist/lib/windowUtil.d.ts.map +1 -0
- package/dist/lib/windowUtil.js.map +1 -0
- package/dist/nextjs/NextClientAuthenticationRefresher.d.ts.map +1 -0
- package/dist/nextjs/NextClientAuthenticationRefresher.js.map +1 -0
- package/dist/nextjs/NextServerAuthenticationRefresherImpl.d.ts +11 -0
- package/dist/nextjs/NextServerAuthenticationRefresherImpl.d.ts.map +1 -0
- package/dist/nextjs/NextServerAuthenticationRefresherImpl.js +17 -0
- package/dist/nextjs/NextServerAuthenticationRefresherImpl.js.map +1 -0
- package/dist/nextjs/config.d.ts.map +1 -0
- package/dist/nextjs/config.js.map +1 -0
- package/dist/nextjs/cookies.d.ts +16 -0
- package/dist/nextjs/cookies.d.ts.map +1 -0
- package/dist/nextjs/cookies.js +41 -0
- package/dist/nextjs/cookies.js.map +1 -0
- package/dist/nextjs/hooks/index.d.ts.map +1 -0
- package/dist/nextjs/hooks/index.js.map +1 -0
- package/dist/nextjs/hooks/usePrevious.d.ts.map +1 -0
- package/dist/nextjs/hooks/usePrevious.js.map +1 -0
- package/dist/nextjs/hooks/useRefresh.d.ts.map +1 -0
- package/dist/nextjs/hooks/useRefresh.js.map +1 -0
- package/dist/nextjs/hooks/useUserCookie.d.ts.map +1 -0
- package/dist/nextjs/hooks/useUserCookie.js.map +1 -0
- package/dist/nextjs/index.d.ts.map +1 -0
- package/dist/nextjs/index.js.map +1 -0
- package/dist/nextjs/middleware/index.d.ts.map +1 -0
- package/dist/nextjs/middleware/index.js.map +1 -0
- package/dist/nextjs/middleware.d.ts.map +1 -0
- package/dist/nextjs/middleware.js +101 -0
- package/dist/nextjs/middleware.js.map +1 -0
- package/dist/nextjs/providers/NextAuthProvider.d.ts.map +1 -0
- package/dist/nextjs/providers/NextAuthProvider.js.map +1 -0
- package/dist/nextjs/routeHandler.d.ts.map +1 -0
- package/dist/nextjs/routeHandler.js +312 -0
- package/dist/nextjs/routeHandler.js.map +1 -0
- package/dist/nextjs/utils.d.ts.map +1 -0
- package/dist/nextjs/utils.js.map +1 -0
- package/dist/reactjs/components/ButtonContentOrLoader.d.ts.map +1 -0
- package/dist/reactjs/components/ButtonContentOrLoader.js.map +1 -0
- package/dist/reactjs/components/SignInButton.d.ts.map +1 -0
- package/dist/reactjs/components/SignInButton.js.map +1 -0
- package/dist/reactjs/components/SignOutButton.d.ts.map +1 -0
- package/dist/reactjs/components/SignOutButton.js.map +1 -0
- package/dist/reactjs/components/UserButton.d.ts.map +1 -0
- package/dist/reactjs/components/UserButton.js +142 -0
- package/dist/reactjs/components/UserButton.js.map +1 -0
- package/dist/reactjs/components/index.d.ts.map +1 -0
- package/dist/reactjs/components/index.js.map +1 -0
- package/dist/reactjs/components/utils.d.ts.map +1 -0
- package/dist/reactjs/components/utils.js.map +1 -0
- package/dist/reactjs/hooks/index.d.ts.map +1 -0
- package/dist/reactjs/hooks/index.js.map +1 -0
- package/dist/reactjs/hooks/useClientTokenExchangeSession.d.ts.map +1 -0
- package/dist/reactjs/hooks/useClientTokenExchangeSession.js.map +1 -0
- package/dist/reactjs/hooks/useUser.d.ts.map +1 -0
- package/dist/reactjs/hooks/useUser.js.map +1 -0
- package/dist/reactjs/index.d.ts.map +1 -0
- package/dist/reactjs/index.js.map +1 -0
- package/dist/reactjs/providers/AuthProvider.d.ts.map +1 -0
- package/dist/reactjs/providers/AuthProvider.js.map +1 -0
- package/dist/reactjs/providers/CivicAuthProvider.d.ts.map +1 -0
- package/dist/reactjs/providers/CivicAuthProvider.js.map +1 -0
- package/dist/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -0
- package/dist/reactjs/providers/ClientTokenExchangeSessionProvider.js.map +1 -0
- package/dist/reactjs/providers/index.d.ts.map +1 -0
- package/dist/reactjs/providers/index.js.map +1 -0
- package/dist/server/ServerAuthenticationResolver.d.ts.map +1 -0
- package/dist/server/ServerAuthenticationResolver.js +67 -0
- package/dist/server/ServerAuthenticationResolver.js.map +1 -0
- package/dist/server/config.d.ts.map +1 -0
- package/dist/server/config.js.map +1 -0
- package/dist/server/index.d.ts.map +1 -0
- package/dist/server/index.js.map +1 -0
- package/dist/server/login.d.ts.map +1 -0
- package/dist/server/login.js.map +1 -0
- package/dist/server/logout.d.ts.map +1 -0
- package/dist/server/logout.js.map +1 -0
- package/dist/server/refresh.d.ts.map +1 -0
- package/dist/server/refresh.js.map +1 -0
- package/dist/services/AuthenticationService.d.ts +93 -0
- package/dist/services/AuthenticationService.d.ts.map +1 -0
- package/dist/services/AuthenticationService.js +366 -0
- package/dist/services/AuthenticationService.js.map +1 -0
- package/dist/services/PKCE.d.ts.map +1 -0
- package/dist/services/PKCE.js.map +1 -0
- package/dist/services/types.d.ts.map +1 -0
- package/dist/services/types.js.map +1 -0
- package/dist/shared/components/BlockDisplay.d.ts.map +1 -0
- package/dist/shared/components/BlockDisplay.js +29 -0
- package/dist/shared/components/BlockDisplay.js.map +1 -0
- package/dist/shared/components/CivicAuthIframe.d.ts.map +1 -0
- package/dist/shared/components/CivicAuthIframe.js +27 -0
- package/dist/shared/components/CivicAuthIframe.js.map +1 -0
- package/dist/shared/components/CivicAuthIframeContainer.d.ts.map +1 -0
- package/dist/shared/components/CivicAuthIframeContainer.js +154 -0
- package/dist/shared/components/CivicAuthIframeContainer.js.map +1 -0
- package/dist/shared/components/CivicAuthLogoutIframeContainer.d.ts.map +1 -0
- package/dist/shared/components/CivicAuthLogoutIframeContainer.js +19 -0
- package/dist/shared/components/CivicAuthLogoutIframeContainer.js.map +1 -0
- package/dist/shared/components/CloseIcon.d.ts.map +1 -0
- package/dist/shared/components/CloseIcon.js.map +1 -0
- package/dist/shared/components/IFrameAndLoading.d.ts.map +1 -0
- package/dist/shared/components/IFrameAndLoading.js.map +1 -0
- package/dist/shared/components/LoadingIcon.d.ts.map +1 -0
- package/dist/shared/components/LoadingIcon.js.map +1 -0
- package/dist/shared/components/SVGLoading.d.ts +4 -0
- package/dist/shared/components/SVGLoading.d.ts.map +1 -0
- package/dist/shared/components/SVGLoading.js +28 -0
- package/dist/shared/components/SVGLoading.js.map +1 -0
- package/dist/shared/hooks/index.d.ts.map +1 -0
- package/dist/shared/hooks/index.js.map +1 -0
- package/dist/shared/hooks/useAuth.d.ts.map +1 -0
- package/dist/shared/hooks/useAuth.js.map +1 -0
- package/dist/shared/hooks/useCivicAuthConfig.d.ts.map +1 -0
- package/dist/shared/hooks/useCivicAuthConfig.js.map +1 -0
- package/dist/shared/hooks/useCurrentUrl.d.ts.map +1 -0
- package/dist/shared/hooks/useCurrentUrl.js.map +1 -0
- package/dist/shared/hooks/useIframe.d.ts.map +1 -0
- package/dist/shared/hooks/useIframe.js.map +1 -0
- package/dist/shared/hooks/useIsInIframe.d.ts.map +1 -0
- package/dist/shared/hooks/useIsInIframe.js.map +1 -0
- package/dist/shared/hooks/useOAuthEndpoints.d.ts.map +1 -0
- package/dist/shared/hooks/useOAuthEndpoints.js.map +1 -0
- package/dist/shared/hooks/useRefresh.d.ts.map +1 -0
- package/dist/shared/hooks/useRefresh.js.map +1 -0
- package/dist/shared/hooks/useSession.d.ts.map +1 -0
- package/dist/shared/hooks/useSession.js.map +1 -0
- package/dist/shared/hooks/useSignIn.d.ts.map +1 -0
- package/dist/shared/hooks/useSignIn.js +168 -0
- package/dist/shared/hooks/useSignIn.js.map +1 -0
- package/dist/shared/hooks/useToken.d.ts.map +1 -0
- package/dist/shared/hooks/useToken.js.map +1 -0
- package/dist/shared/hooks/useWindowFocused.d.ts.map +1 -0
- package/dist/shared/hooks/useWindowFocused.js.map +1 -0
- package/dist/shared/index.d.ts.map +1 -0
- package/dist/shared/index.js.map +1 -0
- package/dist/shared/lib/AuthenticationRefresherImpl.d.ts +14 -0
- package/dist/shared/lib/AuthenticationRefresherImpl.d.ts.map +1 -0
- package/dist/shared/lib/AuthenticationRefresherImpl.js +48 -0
- package/dist/shared/lib/AuthenticationRefresherImpl.js.map +1 -0
- package/dist/shared/lib/BrowserCookieStorage.d.ts +9 -0
- package/dist/shared/lib/BrowserCookieStorage.d.ts.map +1 -0
- package/dist/shared/lib/BrowserCookieStorage.js +56 -0
- package/dist/shared/lib/BrowserCookieStorage.js.map +1 -0
- package/dist/shared/lib/GenericAuthenticationRefresher.d.ts.map +1 -0
- package/dist/shared/lib/GenericAuthenticationRefresher.js.map +1 -0
- package/dist/shared/lib/UserSession.d.ts.map +1 -0
- package/dist/shared/lib/UserSession.js.map +1 -0
- package/dist/shared/lib/iframeUtils.d.ts.map +1 -0
- package/dist/shared/lib/iframeUtils.js.map +1 -0
- package/dist/shared/lib/session.d.ts.map +1 -0
- package/dist/shared/lib/session.js.map +1 -0
- package/dist/shared/lib/storage.d.ts +35 -0
- package/dist/shared/lib/storage.d.ts.map +1 -0
- package/dist/shared/lib/storage.js.map +1 -0
- package/dist/shared/lib/types.d.ts +39 -0
- package/dist/shared/lib/types.d.ts.map +1 -0
- package/dist/shared/lib/types.js.map +1 -0
- package/dist/shared/lib/util.d.ts +40 -0
- package/dist/shared/lib/util.d.ts.map +1 -0
- package/dist/shared/lib/util.js +187 -0
- package/dist/shared/lib/util.js.map +1 -0
- package/dist/shared/providers/AuthContext.d.ts.map +1 -0
- package/dist/shared/providers/AuthContext.js.map +1 -0
- package/dist/shared/providers/CivicAuthConfigContext.d.ts.map +1 -0
- package/dist/shared/providers/CivicAuthConfigContext.js.map +1 -0
- package/dist/shared/providers/IframeProvider.d.ts +25 -0
- package/dist/shared/providers/IframeProvider.d.ts.map +1 -0
- package/dist/shared/providers/IframeProvider.js +59 -0
- package/dist/shared/providers/IframeProvider.js.map +1 -0
- package/dist/shared/providers/SessionProvider.d.ts.map +1 -0
- package/dist/shared/providers/SessionProvider.js.map +1 -0
- package/dist/shared/providers/TokenProvider.d.ts.map +1 -0
- package/dist/shared/providers/TokenProvider.js.map +1 -0
- package/dist/shared/providers/UserProvider.d.ts.map +1 -0
- package/dist/shared/providers/UserProvider.js.map +1 -0
- package/dist/shared/providers/types.d.ts.map +1 -0
- package/dist/shared/providers/types.js.map +1 -0
- package/dist/shared/version.d.ts +2 -0
- package/dist/shared/version.d.ts.map +1 -0
- package/dist/shared/version.js +3 -0
- package/dist/shared/version.js.map +1 -0
- package/dist/types.d.ts +163 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js.map +1 -0
- package/dist/utils.d.ts.map +1 -0
- package/dist/utils.js.map +1 -0
- package/dist/version.d.ts.map +1 -0
- package/dist/version.js.map +1 -0
- package/package.json +21 -37
- package/dist/cjs/browser/storage.d.ts.map +0 -1
- package/dist/cjs/browser/storage.js +0 -24
- package/dist/cjs/browser/storage.js.map +0 -1
- package/dist/cjs/config.d.ts.map +0 -1
- package/dist/cjs/config.js +0 -8
- package/dist/cjs/config.js.map +0 -1
- package/dist/cjs/constants.d.ts +0 -12
- package/dist/cjs/constants.d.ts.map +0 -1
- package/dist/cjs/constants.js +0 -38
- package/dist/cjs/constants.js.map +0 -1
- package/dist/cjs/index.d.ts.map +0 -1
- package/dist/cjs/index.js +0 -11
- package/dist/cjs/index.js.map +0 -1
- package/dist/cjs/lib/cookies.d.ts.map +0 -1
- package/dist/cjs/lib/cookies.js +0 -29
- package/dist/cjs/lib/cookies.js.map +0 -1
- package/dist/cjs/lib/jwt.d.ts.map +0 -1
- package/dist/cjs/lib/jwt.js +0 -13
- package/dist/cjs/lib/jwt.js.map +0 -1
- package/dist/cjs/lib/logger.d.ts.map +0 -1
- package/dist/cjs/lib/logger.js +0 -62
- package/dist/cjs/lib/logger.js.map +0 -1
- package/dist/cjs/lib/oauth.d.ts.map +0 -1
- package/dist/cjs/lib/oauth.js +0 -74
- package/dist/cjs/lib/oauth.js.map +0 -1
- package/dist/cjs/lib/obj.d.ts.map +0 -1
- package/dist/cjs/lib/obj.js +0 -21
- package/dist/cjs/lib/obj.js.map +0 -1
- package/dist/cjs/lib/postMessage.d.ts.map +0 -1
- package/dist/cjs/lib/postMessage.js +0 -17
- package/dist/cjs/lib/postMessage.js.map +0 -1
- package/dist/cjs/lib/windowUtil.d.ts.map +0 -1
- package/dist/cjs/lib/windowUtil.js +0 -35
- package/dist/cjs/lib/windowUtil.js.map +0 -1
- package/dist/cjs/nextjs/GetUser.d.ts +0 -6
- package/dist/cjs/nextjs/GetUser.d.ts.map +0 -1
- package/dist/cjs/nextjs/GetUser.js +0 -11
- package/dist/cjs/nextjs/GetUser.js.map +0 -1
- package/dist/cjs/nextjs/NextClientAuthenticationRefresher.d.ts.map +0 -1
- package/dist/cjs/nextjs/NextClientAuthenticationRefresher.js +0 -26
- package/dist/cjs/nextjs/NextClientAuthenticationRefresher.js.map +0 -1
- package/dist/cjs/nextjs/config.d.ts +0 -209
- package/dist/cjs/nextjs/config.d.ts.map +0 -1
- package/dist/cjs/nextjs/config.js +0 -191
- package/dist/cjs/nextjs/config.js.map +0 -1
- package/dist/cjs/nextjs/cookies.d.ts +0 -27
- package/dist/cjs/nextjs/cookies.d.ts.map +0 -1
- package/dist/cjs/nextjs/cookies.js +0 -141
- package/dist/cjs/nextjs/cookies.js.map +0 -1
- package/dist/cjs/nextjs/hooks/index.d.ts.map +0 -1
- package/dist/cjs/nextjs/hooks/index.js +0 -6
- package/dist/cjs/nextjs/hooks/index.js.map +0 -1
- package/dist/cjs/nextjs/hooks/usePrevious.d.ts.map +0 -1
- package/dist/cjs/nextjs/hooks/usePrevious.js +0 -12
- package/dist/cjs/nextjs/hooks/usePrevious.js.map +0 -1
- package/dist/cjs/nextjs/hooks/useRefresh.d.ts.map +0 -1
- package/dist/cjs/nextjs/hooks/useRefresh.js +0 -43
- package/dist/cjs/nextjs/hooks/useRefresh.js.map +0 -1
- package/dist/cjs/nextjs/hooks/useUserCookie.d.ts.map +0 -1
- package/dist/cjs/nextjs/hooks/useUserCookie.js +0 -93
- package/dist/cjs/nextjs/hooks/useUserCookie.js.map +0 -1
- package/dist/cjs/nextjs/index.d.ts.map +0 -1
- package/dist/cjs/nextjs/index.js +0 -27
- package/dist/cjs/nextjs/index.js.map +0 -1
- package/dist/cjs/nextjs/middleware/index.d.ts.map +0 -1
- package/dist/cjs/nextjs/middleware/index.js +0 -10
- package/dist/cjs/nextjs/middleware/index.js.map +0 -1
- package/dist/cjs/nextjs/middleware.d.ts.map +0 -1
- package/dist/cjs/nextjs/middleware.js +0 -111
- package/dist/cjs/nextjs/middleware.js.map +0 -1
- package/dist/cjs/nextjs/providers/NextAuthProvider.d.ts.map +0 -1
- package/dist/cjs/nextjs/providers/NextAuthProvider.js +0 -102
- package/dist/cjs/nextjs/providers/NextAuthProvider.js.map +0 -1
- package/dist/cjs/nextjs/routeHandler.d.ts.map +0 -1
- package/dist/cjs/nextjs/routeHandler.js +0 -318
- package/dist/cjs/nextjs/routeHandler.js.map +0 -1
- package/dist/cjs/nextjs/utils.d.ts.map +0 -1
- package/dist/cjs/nextjs/utils.js +0 -9
- package/dist/cjs/nextjs/utils.js.map +0 -1
- package/dist/cjs/reactjs/components/ButtonContentOrLoader.d.ts.map +0 -1
- package/dist/cjs/reactjs/components/ButtonContentOrLoader.js +0 -40
- package/dist/cjs/reactjs/components/ButtonContentOrLoader.js.map +0 -1
- package/dist/cjs/reactjs/components/SignInButton.d.ts.map +0 -1
- package/dist/cjs/reactjs/components/SignInButton.js +0 -31
- package/dist/cjs/reactjs/components/SignInButton.js.map +0 -1
- package/dist/cjs/reactjs/components/SignOutButton.d.ts.map +0 -1
- package/dist/cjs/reactjs/components/SignOutButton.js +0 -27
- package/dist/cjs/reactjs/components/SignOutButton.js.map +0 -1
- package/dist/cjs/reactjs/components/UserButton.d.ts.map +0 -1
- package/dist/cjs/reactjs/components/UserButton.js +0 -146
- package/dist/cjs/reactjs/components/UserButton.js.map +0 -1
- package/dist/cjs/reactjs/components/index.d.ts.map +0 -1
- package/dist/cjs/reactjs/components/index.js +0 -14
- package/dist/cjs/reactjs/components/index.js.map +0 -1
- package/dist/cjs/reactjs/components/utils.d.ts.map +0 -1
- package/dist/cjs/reactjs/components/utils.js +0 -31
- package/dist/cjs/reactjs/components/utils.js.map +0 -1
- package/dist/cjs/reactjs/hooks/index.d.ts.map +0 -1
- package/dist/cjs/reactjs/hooks/index.js +0 -8
- package/dist/cjs/reactjs/hooks/index.js.map +0 -1
- package/dist/cjs/reactjs/hooks/useAuth.d.ts.map +0 -1
- package/dist/cjs/reactjs/hooks/useAuth.js +0 -15
- package/dist/cjs/reactjs/hooks/useAuth.js.map +0 -1
- package/dist/cjs/reactjs/hooks/useClientTokenExchangeSession.d.ts.map +0 -1
- package/dist/cjs/reactjs/hooks/useClientTokenExchangeSession.js +0 -16
- package/dist/cjs/reactjs/hooks/useClientTokenExchangeSession.js.map +0 -1
- package/dist/cjs/reactjs/hooks/useSignIn.d.ts +0 -6
- package/dist/cjs/reactjs/hooks/useSignIn.d.ts.map +0 -1
- package/dist/cjs/reactjs/hooks/useSignIn.js +0 -38
- package/dist/cjs/reactjs/hooks/useSignIn.js.map +0 -1
- package/dist/cjs/reactjs/hooks/useUser.d.ts.map +0 -1
- package/dist/cjs/reactjs/hooks/useUser.js +0 -15
- package/dist/cjs/reactjs/hooks/useUser.js.map +0 -1
- package/dist/cjs/reactjs/index.d.ts.map +0 -1
- package/dist/cjs/reactjs/index.js +0 -32
- package/dist/cjs/reactjs/index.js.map +0 -1
- package/dist/cjs/reactjs/providers/AuthProvider.d.ts.map +0 -1
- package/dist/cjs/reactjs/providers/AuthProvider.js +0 -91
- package/dist/cjs/reactjs/providers/AuthProvider.js.map +0 -1
- package/dist/cjs/reactjs/providers/CivicAuthProvider.d.ts.map +0 -1
- package/dist/cjs/reactjs/providers/CivicAuthProvider.js +0 -29
- package/dist/cjs/reactjs/providers/CivicAuthProvider.js.map +0 -1
- package/dist/cjs/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts.map +0 -1
- package/dist/cjs/reactjs/providers/ClientTokenExchangeSessionProvider.js +0 -147
- package/dist/cjs/reactjs/providers/ClientTokenExchangeSessionProvider.js.map +0 -1
- package/dist/cjs/reactjs/providers/index.d.ts.map +0 -1
- package/dist/cjs/reactjs/providers/index.js +0 -19
- package/dist/cjs/reactjs/providers/index.js.map +0 -1
- package/dist/cjs/server/ServerAuthenticationResolver.d.ts.map +0 -1
- package/dist/cjs/server/ServerAuthenticationResolver.js +0 -71
- package/dist/cjs/server/ServerAuthenticationResolver.js.map +0 -1
- package/dist/cjs/server/config.d.ts.map +0 -1
- package/dist/cjs/server/config.js +0 -3
- package/dist/cjs/server/config.js.map +0 -1
- package/dist/cjs/server/index.d.ts.map +0 -1
- package/dist/cjs/server/index.js +0 -21
- package/dist/cjs/server/index.js.map +0 -1
- package/dist/cjs/server/login.d.ts.map +0 -1
- package/dist/cjs/server/login.js +0 -42
- package/dist/cjs/server/login.js.map +0 -1
- package/dist/cjs/server/logout.d.ts.map +0 -1
- package/dist/cjs/server/logout.js +0 -26
- package/dist/cjs/server/logout.js.map +0 -1
- package/dist/cjs/server/refresh.d.ts.map +0 -1
- package/dist/cjs/server/refresh.js +0 -16
- package/dist/cjs/server/refresh.js.map +0 -1
- package/dist/cjs/services/AuthenticationService.d.ts +0 -91
- package/dist/cjs/services/AuthenticationService.d.ts.map +0 -1
- package/dist/cjs/services/AuthenticationService.js +0 -358
- package/dist/cjs/services/AuthenticationService.js.map +0 -1
- package/dist/cjs/services/PKCE.d.ts.map +0 -1
- package/dist/cjs/services/PKCE.js +0 -50
- package/dist/cjs/services/PKCE.js.map +0 -1
- package/dist/cjs/services/types.d.ts.map +0 -1
- package/dist/cjs/services/types.js +0 -11
- package/dist/cjs/services/types.js.map +0 -1
- package/dist/cjs/shared/components/BlockDisplay.d.ts.map +0 -1
- package/dist/cjs/shared/components/BlockDisplay.js +0 -27
- package/dist/cjs/shared/components/BlockDisplay.js.map +0 -1
- package/dist/cjs/shared/components/CivicAuthIframe.d.ts.map +0 -1
- package/dist/cjs/shared/components/CivicAuthIframe.js +0 -69
- package/dist/cjs/shared/components/CivicAuthIframe.js.map +0 -1
- package/dist/cjs/shared/components/CivicAuthIframeContainer.d.ts.map +0 -1
- package/dist/cjs/shared/components/CivicAuthIframeContainer.js +0 -159
- package/dist/cjs/shared/components/CivicAuthIframeContainer.js.map +0 -1
- package/dist/cjs/shared/components/CivicAuthLogoutIframeContainer.d.ts.map +0 -1
- package/dist/cjs/shared/components/CivicAuthLogoutIframeContainer.js +0 -22
- package/dist/cjs/shared/components/CivicAuthLogoutIframeContainer.js.map +0 -1
- package/dist/cjs/shared/components/CloseIcon.d.ts.map +0 -1
- package/dist/cjs/shared/components/CloseIcon.js +0 -7
- package/dist/cjs/shared/components/CloseIcon.js.map +0 -1
- package/dist/cjs/shared/components/IFrameAndLoading.d.ts.map +0 -1
- package/dist/cjs/shared/components/IFrameAndLoading.js +0 -39
- package/dist/cjs/shared/components/IFrameAndLoading.js.map +0 -1
- package/dist/cjs/shared/components/LoadingIcon.d.ts.map +0 -1
- package/dist/cjs/shared/components/LoadingIcon.js +0 -28
- package/dist/cjs/shared/components/LoadingIcon.js.map +0 -1
- package/dist/cjs/shared/components/SVGLoading.d.ts +0 -2
- package/dist/cjs/shared/components/SVGLoading.d.ts.map +0 -1
- package/dist/cjs/shared/components/SVGLoading.js +0 -30
- package/dist/cjs/shared/components/SVGLoading.js.map +0 -1
- package/dist/cjs/shared/hooks/index.d.ts.map +0 -1
- package/dist/cjs/shared/hooks/index.js +0 -24
- package/dist/cjs/shared/hooks/index.js.map +0 -1
- package/dist/cjs/shared/hooks/useAuth.d.ts +0 -3
- package/dist/cjs/shared/hooks/useAuth.d.ts.map +0 -1
- package/dist/cjs/shared/hooks/useAuth.js +0 -15
- package/dist/cjs/shared/hooks/useAuth.js.map +0 -1
- package/dist/cjs/shared/hooks/useCivicAuthConfig.d.ts +0 -3
- package/dist/cjs/shared/hooks/useCivicAuthConfig.d.ts.map +0 -1
- package/dist/cjs/shared/hooks/useCivicAuthConfig.js +0 -13
- package/dist/cjs/shared/hooks/useCivicAuthConfig.js.map +0 -1
- package/dist/cjs/shared/hooks/useClientTokenExchangeSession.d.ts +0 -3
- package/dist/cjs/shared/hooks/useClientTokenExchangeSession.d.ts.map +0 -1
- package/dist/cjs/shared/hooks/useClientTokenExchangeSession.js +0 -16
- package/dist/cjs/shared/hooks/useClientTokenExchangeSession.js.map +0 -1
- package/dist/cjs/shared/hooks/useCurrentUrl.d.ts.map +0 -1
- package/dist/cjs/shared/hooks/useCurrentUrl.js +0 -27
- package/dist/cjs/shared/hooks/useCurrentUrl.js.map +0 -1
- package/dist/cjs/shared/hooks/useIframe.d.ts.map +0 -1
- package/dist/cjs/shared/hooks/useIframe.js +0 -16
- package/dist/cjs/shared/hooks/useIframe.js.map +0 -1
- package/dist/cjs/shared/hooks/useIsInIframe.d.ts.map +0 -1
- package/dist/cjs/shared/hooks/useIsInIframe.js +0 -17
- package/dist/cjs/shared/hooks/useIsInIframe.js.map +0 -1
- package/dist/cjs/shared/hooks/useOAuthEndpoints.d.ts.map +0 -1
- package/dist/cjs/shared/hooks/useOAuthEndpoints.js +0 -17
- package/dist/cjs/shared/hooks/useOAuthEndpoints.js.map +0 -1
- package/dist/cjs/shared/hooks/useRefresh.d.ts.map +0 -1
- package/dist/cjs/shared/hooks/useRefresh.js +0 -41
- package/dist/cjs/shared/hooks/useRefresh.js.map +0 -1
- package/dist/cjs/shared/hooks/useSession.d.ts.map +0 -1
- package/dist/cjs/shared/hooks/useSession.js +0 -16
- package/dist/cjs/shared/hooks/useSession.js.map +0 -1
- package/dist/cjs/shared/hooks/useSignIn.d.ts.map +0 -1
- package/dist/cjs/shared/hooks/useSignIn.js +0 -168
- package/dist/cjs/shared/hooks/useSignIn.js.map +0 -1
- package/dist/cjs/shared/hooks/useToken.d.ts.map +0 -1
- package/dist/cjs/shared/hooks/useToken.js +0 -15
- package/dist/cjs/shared/hooks/useToken.js.map +0 -1
- package/dist/cjs/shared/hooks/useWindowFocused.d.ts.map +0 -1
- package/dist/cjs/shared/hooks/useWindowFocused.js +0 -24
- package/dist/cjs/shared/hooks/useWindowFocused.js.map +0 -1
- package/dist/cjs/shared/index.d.ts.map +0 -1
- package/dist/cjs/shared/index.js +0 -25
- package/dist/cjs/shared/index.js.map +0 -1
- package/dist/cjs/shared/lib/AuthenticationRefresherImpl.d.ts +0 -13
- package/dist/cjs/shared/lib/AuthenticationRefresherImpl.d.ts.map +0 -1
- package/dist/cjs/shared/lib/AuthenticationRefresherImpl.js +0 -47
- package/dist/cjs/shared/lib/AuthenticationRefresherImpl.js.map +0 -1
- package/dist/cjs/shared/lib/BrowserCookieStorage.d.ts +0 -8
- package/dist/cjs/shared/lib/BrowserCookieStorage.d.ts.map +0 -1
- package/dist/cjs/shared/lib/BrowserCookieStorage.js +0 -56
- package/dist/cjs/shared/lib/BrowserCookieStorage.js.map +0 -1
- package/dist/cjs/shared/lib/GenericAuthenticationRefresher.d.ts.map +0 -1
- package/dist/cjs/shared/lib/GenericAuthenticationRefresher.js +0 -65
- package/dist/cjs/shared/lib/GenericAuthenticationRefresher.js.map +0 -1
- package/dist/cjs/shared/lib/UserSession.d.ts.map +0 -1
- package/dist/cjs/shared/lib/UserSession.js +0 -27
- package/dist/cjs/shared/lib/UserSession.js.map +0 -1
- package/dist/cjs/shared/lib/iframeUtils.d.ts.map +0 -1
- package/dist/cjs/shared/lib/iframeUtils.js +0 -11
- package/dist/cjs/shared/lib/iframeUtils.js.map +0 -1
- package/dist/cjs/shared/lib/session.d.ts.map +0 -1
- package/dist/cjs/shared/lib/session.js +0 -48
- package/dist/cjs/shared/lib/session.js.map +0 -1
- package/dist/cjs/shared/lib/storage.d.ts +0 -34
- package/dist/cjs/shared/lib/storage.d.ts.map +0 -1
- package/dist/cjs/shared/lib/storage.js +0 -21
- package/dist/cjs/shared/lib/storage.js.map +0 -1
- package/dist/cjs/shared/lib/types.d.ts +0 -38
- package/dist/cjs/shared/lib/types.d.ts.map +0 -1
- package/dist/cjs/shared/lib/types.js +0 -22
- package/dist/cjs/shared/lib/types.js.map +0 -1
- package/dist/cjs/shared/lib/util.d.ts +0 -37
- package/dist/cjs/shared/lib/util.d.ts.map +0 -1
- package/dist/cjs/shared/lib/util.js +0 -204
- package/dist/cjs/shared/lib/util.js.map +0 -1
- package/dist/cjs/shared/providers/AuthContext.d.ts.map +0 -1
- package/dist/cjs/shared/providers/AuthContext.js +0 -7
- package/dist/cjs/shared/providers/AuthContext.js.map +0 -1
- package/dist/cjs/shared/providers/AuthProvider.d.ts +0 -22
- package/dist/cjs/shared/providers/AuthProvider.d.ts.map +0 -1
- package/dist/cjs/shared/providers/AuthProvider.js +0 -108
- package/dist/cjs/shared/providers/AuthProvider.js.map +0 -1
- package/dist/cjs/shared/providers/CivicAuthConfigContext.d.ts.map +0 -1
- package/dist/cjs/shared/providers/CivicAuthConfigContext.js +0 -59
- package/dist/cjs/shared/providers/CivicAuthConfigContext.js.map +0 -1
- package/dist/cjs/shared/providers/CivicAuthProvider.d.ts +0 -6
- package/dist/cjs/shared/providers/CivicAuthProvider.d.ts.map +0 -1
- package/dist/cjs/shared/providers/CivicAuthProvider.js +0 -38
- package/dist/cjs/shared/providers/CivicAuthProvider.js.map +0 -1
- package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.d.ts +0 -17
- package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.d.ts.map +0 -1
- package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.js +0 -168
- package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.js.map +0 -1
- package/dist/cjs/shared/providers/IframeProvider.d.ts +0 -24
- package/dist/cjs/shared/providers/IframeProvider.d.ts.map +0 -1
- package/dist/cjs/shared/providers/IframeProvider.js +0 -45
- package/dist/cjs/shared/providers/IframeProvider.js.map +0 -1
- package/dist/cjs/shared/providers/SessionProvider.d.ts.map +0 -1
- package/dist/cjs/shared/providers/SessionProvider.js +0 -28
- package/dist/cjs/shared/providers/SessionProvider.js.map +0 -1
- package/dist/cjs/shared/providers/TokenProvider.d.ts.map +0 -1
- package/dist/cjs/shared/providers/TokenProvider.js +0 -39
- package/dist/cjs/shared/providers/TokenProvider.js.map +0 -1
- package/dist/cjs/shared/providers/UserProvider.d.ts.map +0 -1
- package/dist/cjs/shared/providers/UserProvider.js +0 -69
- package/dist/cjs/shared/providers/UserProvider.js.map +0 -1
- package/dist/cjs/shared/providers/types.d.ts.map +0 -1
- package/dist/cjs/shared/providers/types.js +0 -3
- package/dist/cjs/shared/providers/types.js.map +0 -1
- package/dist/cjs/shared/version.d.ts +0 -2
- package/dist/cjs/shared/version.d.ts.map +0 -1
- package/dist/cjs/shared/version.js +0 -6
- package/dist/cjs/shared/version.js.map +0 -1
- package/dist/cjs/types.d.ts +0 -159
- package/dist/cjs/types.d.ts.map +0 -1
- package/dist/cjs/types.js +0 -20
- package/dist/cjs/types.js.map +0 -1
- package/dist/cjs/utils.d.ts.map +0 -1
- package/dist/cjs/utils.js +0 -47
- package/dist/cjs/utils.js.map +0 -1
- package/dist/cjs/version.d.ts.map +0 -1
- package/dist/cjs/version.js +0 -6
- package/dist/cjs/version.js.map +0 -1
- package/dist/esm/browser/storage.d.ts +0 -10
- package/dist/esm/browser/storage.d.ts.map +0 -1
- package/dist/esm/browser/storage.js.map +0 -1
- package/dist/esm/config.d.ts +0 -3
- package/dist/esm/config.d.ts.map +0 -1
- package/dist/esm/config.js.map +0 -1
- package/dist/esm/constants.d.ts +0 -12
- package/dist/esm/constants.d.ts.map +0 -1
- package/dist/esm/constants.js +0 -26
- package/dist/esm/constants.js.map +0 -1
- package/dist/esm/index.d.ts +0 -8
- package/dist/esm/index.d.ts.map +0 -1
- package/dist/esm/index.js.map +0 -1
- package/dist/esm/lib/cookies.d.ts +0 -7
- package/dist/esm/lib/cookies.d.ts.map +0 -1
- package/dist/esm/lib/cookies.js.map +0 -1
- package/dist/esm/lib/jwt.d.ts +0 -3
- package/dist/esm/lib/jwt.d.ts.map +0 -1
- package/dist/esm/lib/jwt.js.map +0 -1
- package/dist/esm/lib/logger.d.ts +0 -26
- package/dist/esm/lib/logger.d.ts.map +0 -1
- package/dist/esm/lib/logger.js.map +0 -1
- package/dist/esm/lib/oauth.d.ts +0 -19
- package/dist/esm/lib/oauth.d.ts.map +0 -1
- package/dist/esm/lib/oauth.js.map +0 -1
- package/dist/esm/lib/obj.d.ts +0 -3
- package/dist/esm/lib/obj.d.ts.map +0 -1
- package/dist/esm/lib/obj.js.map +0 -1
- package/dist/esm/lib/postMessage.d.ts +0 -4
- package/dist/esm/lib/postMessage.d.ts.map +0 -1
- package/dist/esm/lib/postMessage.js +0 -14
- package/dist/esm/lib/postMessage.js.map +0 -1
- package/dist/esm/lib/windowUtil.d.ts +0 -4
- package/dist/esm/lib/windowUtil.d.ts.map +0 -1
- package/dist/esm/lib/windowUtil.js.map +0 -1
- package/dist/esm/nextjs/GetUser.d.ts +0 -6
- package/dist/esm/nextjs/GetUser.d.ts.map +0 -1
- package/dist/esm/nextjs/GetUser.js +0 -7
- package/dist/esm/nextjs/GetUser.js.map +0 -1
- package/dist/esm/nextjs/NextClientAuthenticationRefresher.d.ts +0 -9
- package/dist/esm/nextjs/NextClientAuthenticationRefresher.d.ts.map +0 -1
- package/dist/esm/nextjs/NextClientAuthenticationRefresher.js.map +0 -1
- package/dist/esm/nextjs/config.d.ts.map +0 -1
- package/dist/esm/nextjs/config.js.map +0 -1
- package/dist/esm/nextjs/cookies.d.ts +0 -27
- package/dist/esm/nextjs/cookies.d.ts.map +0 -1
- package/dist/esm/nextjs/cookies.js +0 -103
- package/dist/esm/nextjs/cookies.js.map +0 -1
- package/dist/esm/nextjs/hooks/index.d.ts +0 -2
- package/dist/esm/nextjs/hooks/index.d.ts.map +0 -1
- package/dist/esm/nextjs/hooks/index.js.map +0 -1
- package/dist/esm/nextjs/hooks/usePrevious.d.ts +0 -2
- package/dist/esm/nextjs/hooks/usePrevious.d.ts.map +0 -1
- package/dist/esm/nextjs/hooks/usePrevious.js.map +0 -1
- package/dist/esm/nextjs/hooks/useRefresh.d.ts +0 -4
- package/dist/esm/nextjs/hooks/useRefresh.d.ts.map +0 -1
- package/dist/esm/nextjs/hooks/useRefresh.js.map +0 -1
- package/dist/esm/nextjs/hooks/useUserCookie.d.ts +0 -8
- package/dist/esm/nextjs/hooks/useUserCookie.d.ts.map +0 -1
- package/dist/esm/nextjs/hooks/useUserCookie.js.map +0 -1
- package/dist/esm/nextjs/index.d.ts +0 -9
- package/dist/esm/nextjs/index.d.ts.map +0 -1
- package/dist/esm/nextjs/index.js.map +0 -1
- package/dist/esm/nextjs/middleware/index.d.ts +0 -2
- package/dist/esm/nextjs/middleware/index.d.ts.map +0 -1
- package/dist/esm/nextjs/middleware/index.js.map +0 -1
- package/dist/esm/nextjs/middleware.d.ts +0 -57
- package/dist/esm/nextjs/middleware.d.ts.map +0 -1
- package/dist/esm/nextjs/middleware.js +0 -102
- package/dist/esm/nextjs/middleware.js.map +0 -1
- package/dist/esm/nextjs/providers/NextAuthProvider.d.ts +0 -9
- package/dist/esm/nextjs/providers/NextAuthProvider.d.ts.map +0 -1
- package/dist/esm/nextjs/providers/NextAuthProvider.js.map +0 -1
- package/dist/esm/nextjs/routeHandler.d.ts +0 -19
- package/dist/esm/nextjs/routeHandler.d.ts.map +0 -1
- package/dist/esm/nextjs/routeHandler.js +0 -312
- package/dist/esm/nextjs/routeHandler.js.map +0 -1
- package/dist/esm/nextjs/utils.d.ts +0 -3
- package/dist/esm/nextjs/utils.d.ts.map +0 -1
- package/dist/esm/nextjs/utils.js.map +0 -1
- package/dist/esm/reactjs/components/ButtonContentOrLoader.d.ts +0 -17
- package/dist/esm/reactjs/components/ButtonContentOrLoader.d.ts.map +0 -1
- package/dist/esm/reactjs/components/ButtonContentOrLoader.js.map +0 -1
- package/dist/esm/reactjs/components/SignInButton.d.ts +0 -9
- package/dist/esm/reactjs/components/SignInButton.d.ts.map +0 -1
- package/dist/esm/reactjs/components/SignInButton.js.map +0 -1
- package/dist/esm/reactjs/components/SignOutButton.d.ts +0 -7
- package/dist/esm/reactjs/components/SignOutButton.d.ts.map +0 -1
- package/dist/esm/reactjs/components/SignOutButton.js.map +0 -1
- package/dist/esm/reactjs/components/UserButton.d.ts +0 -9
- package/dist/esm/reactjs/components/UserButton.d.ts.map +0 -1
- package/dist/esm/reactjs/components/UserButton.js +0 -143
- package/dist/esm/reactjs/components/UserButton.js.map +0 -1
- package/dist/esm/reactjs/components/index.d.ts +0 -6
- package/dist/esm/reactjs/components/index.d.ts.map +0 -1
- package/dist/esm/reactjs/components/index.js.map +0 -1
- package/dist/esm/reactjs/components/utils.d.ts +0 -13
- package/dist/esm/reactjs/components/utils.d.ts.map +0 -1
- package/dist/esm/reactjs/components/utils.js.map +0 -1
- package/dist/esm/reactjs/hooks/index.d.ts +0 -3
- package/dist/esm/reactjs/hooks/index.d.ts.map +0 -1
- package/dist/esm/reactjs/hooks/index.js.map +0 -1
- package/dist/esm/reactjs/hooks/useAuth.d.ts +0 -3
- package/dist/esm/reactjs/hooks/useAuth.d.ts.map +0 -1
- package/dist/esm/reactjs/hooks/useAuth.js.map +0 -1
- package/dist/esm/reactjs/hooks/useClientTokenExchangeSession.d.ts +0 -3
- package/dist/esm/reactjs/hooks/useClientTokenExchangeSession.d.ts.map +0 -1
- package/dist/esm/reactjs/hooks/useClientTokenExchangeSession.js.map +0 -1
- package/dist/esm/reactjs/hooks/useSignIn.d.ts +0 -6
- package/dist/esm/reactjs/hooks/useSignIn.d.ts.map +0 -1
- package/dist/esm/reactjs/hooks/useSignIn.js +0 -34
- package/dist/esm/reactjs/hooks/useSignIn.js.map +0 -1
- package/dist/esm/reactjs/hooks/useUser.d.ts +0 -4
- package/dist/esm/reactjs/hooks/useUser.d.ts.map +0 -1
- package/dist/esm/reactjs/hooks/useUser.js.map +0 -1
- package/dist/esm/reactjs/index.d.ts +0 -6
- package/dist/esm/reactjs/index.d.ts.map +0 -1
- package/dist/esm/reactjs/index.js.map +0 -1
- package/dist/esm/reactjs/providers/AuthProvider.d.ts +0 -10
- package/dist/esm/reactjs/providers/AuthProvider.d.ts.map +0 -1
- package/dist/esm/reactjs/providers/AuthProvider.js.map +0 -1
- package/dist/esm/reactjs/providers/CivicAuthProvider.d.ts +0 -5
- package/dist/esm/reactjs/providers/CivicAuthProvider.d.ts.map +0 -1
- package/dist/esm/reactjs/providers/CivicAuthProvider.js.map +0 -1
- package/dist/esm/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts +0 -17
- package/dist/esm/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts.map +0 -1
- package/dist/esm/reactjs/providers/ClientTokenExchangeSessionProvider.js.map +0 -1
- package/dist/esm/reactjs/providers/index.d.ts +0 -8
- package/dist/esm/reactjs/providers/index.d.ts.map +0 -1
- package/dist/esm/reactjs/providers/index.js.map +0 -1
- package/dist/esm/server/ServerAuthenticationResolver.d.ts +0 -20
- package/dist/esm/server/ServerAuthenticationResolver.d.ts.map +0 -1
- package/dist/esm/server/ServerAuthenticationResolver.js +0 -67
- package/dist/esm/server/ServerAuthenticationResolver.js.map +0 -1
- package/dist/esm/server/config.d.ts +0 -11
- package/dist/esm/server/config.d.ts.map +0 -1
- package/dist/esm/server/config.js.map +0 -1
- package/dist/esm/server/index.d.ts +0 -9
- package/dist/esm/server/index.d.ts.map +0 -1
- package/dist/esm/server/index.js.map +0 -1
- package/dist/esm/server/login.d.ts +0 -17
- package/dist/esm/server/login.d.ts.map +0 -1
- package/dist/esm/server/login.js.map +0 -1
- package/dist/esm/server/logout.d.ts +0 -7
- package/dist/esm/server/logout.d.ts.map +0 -1
- package/dist/esm/server/logout.js.map +0 -1
- package/dist/esm/server/refresh.d.ts +0 -7
- package/dist/esm/server/refresh.d.ts.map +0 -1
- package/dist/esm/server/refresh.js.map +0 -1
- package/dist/esm/services/AuthenticationService.d.ts +0 -91
- package/dist/esm/services/AuthenticationService.d.ts.map +0 -1
- package/dist/esm/services/AuthenticationService.js +0 -352
- package/dist/esm/services/AuthenticationService.js.map +0 -1
- package/dist/esm/services/PKCE.d.ts +0 -20
- package/dist/esm/services/PKCE.d.ts.map +0 -1
- package/dist/esm/services/PKCE.js.map +0 -1
- package/dist/esm/services/types.d.ts +0 -24
- package/dist/esm/services/types.d.ts.map +0 -1
- package/dist/esm/services/types.js.map +0 -1
- package/dist/esm/shared/components/BlockDisplay.d.ts +0 -6
- package/dist/esm/shared/components/BlockDisplay.d.ts.map +0 -1
- package/dist/esm/shared/components/BlockDisplay.js +0 -25
- package/dist/esm/shared/components/BlockDisplay.js.map +0 -1
- package/dist/esm/shared/components/CivicAuthIframe.d.ts +0 -9
- package/dist/esm/shared/components/CivicAuthIframe.d.ts.map +0 -1
- package/dist/esm/shared/components/CivicAuthIframe.js +0 -30
- package/dist/esm/shared/components/CivicAuthIframe.js.map +0 -1
- package/dist/esm/shared/components/CivicAuthIframeContainer.d.ts +0 -14
- package/dist/esm/shared/components/CivicAuthIframeContainer.d.ts.map +0 -1
- package/dist/esm/shared/components/CivicAuthIframeContainer.js +0 -155
- package/dist/esm/shared/components/CivicAuthIframeContainer.js.map +0 -1
- package/dist/esm/shared/components/CivicAuthLogoutIframeContainer.d.ts +0 -6
- package/dist/esm/shared/components/CivicAuthLogoutIframeContainer.d.ts.map +0 -1
- package/dist/esm/shared/components/CivicAuthLogoutIframeContainer.js +0 -20
- package/dist/esm/shared/components/CivicAuthLogoutIframeContainer.js.map +0 -1
- package/dist/esm/shared/components/CloseIcon.d.ts +0 -3
- package/dist/esm/shared/components/CloseIcon.d.ts.map +0 -1
- package/dist/esm/shared/components/CloseIcon.js.map +0 -1
- package/dist/esm/shared/components/IFrameAndLoading.d.ts +0 -7
- package/dist/esm/shared/components/IFrameAndLoading.d.ts.map +0 -1
- package/dist/esm/shared/components/IFrameAndLoading.js.map +0 -1
- package/dist/esm/shared/components/LoadingIcon.d.ts +0 -6
- package/dist/esm/shared/components/LoadingIcon.d.ts.map +0 -1
- package/dist/esm/shared/components/LoadingIcon.js.map +0 -1
- package/dist/esm/shared/components/SVGLoading.d.ts +0 -2
- package/dist/esm/shared/components/SVGLoading.d.ts.map +0 -1
- package/dist/esm/shared/components/SVGLoading.js +0 -28
- package/dist/esm/shared/components/SVGLoading.js.map +0 -1
- package/dist/esm/shared/hooks/index.d.ts +0 -11
- package/dist/esm/shared/hooks/index.d.ts.map +0 -1
- package/dist/esm/shared/hooks/index.js.map +0 -1
- package/dist/esm/shared/hooks/useAuth.d.ts +0 -3
- package/dist/esm/shared/hooks/useAuth.d.ts.map +0 -1
- package/dist/esm/shared/hooks/useAuth.js +0 -12
- package/dist/esm/shared/hooks/useAuth.js.map +0 -1
- package/dist/esm/shared/hooks/useCivicAuthConfig.d.ts.map +0 -1
- package/dist/esm/shared/hooks/useCivicAuthConfig.js.map +0 -1
- package/dist/esm/shared/hooks/useClientTokenExchangeSession.d.ts +0 -3
- package/dist/esm/shared/hooks/useClientTokenExchangeSession.d.ts.map +0 -1
- package/dist/esm/shared/hooks/useClientTokenExchangeSession.js +0 -13
- package/dist/esm/shared/hooks/useClientTokenExchangeSession.js.map +0 -1
- package/dist/esm/shared/hooks/useCurrentUrl.d.ts +0 -3
- package/dist/esm/shared/hooks/useCurrentUrl.d.ts.map +0 -1
- package/dist/esm/shared/hooks/useCurrentUrl.js.map +0 -1
- package/dist/esm/shared/hooks/useIframe.d.ts +0 -3
- package/dist/esm/shared/hooks/useIframe.d.ts.map +0 -1
- package/dist/esm/shared/hooks/useIframe.js.map +0 -1
- package/dist/esm/shared/hooks/useIsInIframe.d.ts +0 -3
- package/dist/esm/shared/hooks/useIsInIframe.d.ts.map +0 -1
- package/dist/esm/shared/hooks/useIsInIframe.js.map +0 -1
- package/dist/esm/shared/hooks/useOAuthEndpoints.d.ts +0 -4
- package/dist/esm/shared/hooks/useOAuthEndpoints.d.ts.map +0 -1
- package/dist/esm/shared/hooks/useOAuthEndpoints.js.map +0 -1
- package/dist/esm/shared/hooks/useRefresh.d.ts +0 -4
- package/dist/esm/shared/hooks/useRefresh.d.ts.map +0 -1
- package/dist/esm/shared/hooks/useRefresh.js.map +0 -1
- package/dist/esm/shared/hooks/useSession.d.ts +0 -3
- package/dist/esm/shared/hooks/useSession.d.ts.map +0 -1
- package/dist/esm/shared/hooks/useSession.js.map +0 -1
- package/dist/esm/shared/hooks/useSignIn.d.ts +0 -17
- package/dist/esm/shared/hooks/useSignIn.d.ts.map +0 -1
- package/dist/esm/shared/hooks/useSignIn.js +0 -165
- package/dist/esm/shared/hooks/useSignIn.js.map +0 -1
- package/dist/esm/shared/hooks/useToken.d.ts +0 -3
- package/dist/esm/shared/hooks/useToken.d.ts.map +0 -1
- package/dist/esm/shared/hooks/useToken.js.map +0 -1
- package/dist/esm/shared/hooks/useWindowFocused.d.ts +0 -5
- package/dist/esm/shared/hooks/useWindowFocused.d.ts.map +0 -1
- package/dist/esm/shared/hooks/useWindowFocused.js.map +0 -1
- package/dist/esm/shared/index.d.ts +0 -7
- package/dist/esm/shared/index.d.ts.map +0 -1
- package/dist/esm/shared/index.js.map +0 -1
- package/dist/esm/shared/lib/AuthenticationRefresherImpl.d.ts +0 -13
- package/dist/esm/shared/lib/AuthenticationRefresherImpl.d.ts.map +0 -1
- package/dist/esm/shared/lib/AuthenticationRefresherImpl.js +0 -43
- package/dist/esm/shared/lib/AuthenticationRefresherImpl.js.map +0 -1
- package/dist/esm/shared/lib/BrowserCookieStorage.d.ts +0 -8
- package/dist/esm/shared/lib/BrowserCookieStorage.d.ts.map +0 -1
- package/dist/esm/shared/lib/BrowserCookieStorage.js +0 -52
- package/dist/esm/shared/lib/BrowserCookieStorage.js.map +0 -1
- package/dist/esm/shared/lib/GenericAuthenticationRefresher.d.ts +0 -16
- package/dist/esm/shared/lib/GenericAuthenticationRefresher.d.ts.map +0 -1
- package/dist/esm/shared/lib/GenericAuthenticationRefresher.js.map +0 -1
- package/dist/esm/shared/lib/UserSession.d.ts +0 -17
- package/dist/esm/shared/lib/UserSession.d.ts.map +0 -1
- package/dist/esm/shared/lib/UserSession.js.map +0 -1
- package/dist/esm/shared/lib/iframeUtils.d.ts +0 -6
- package/dist/esm/shared/lib/iframeUtils.d.ts.map +0 -1
- package/dist/esm/shared/lib/iframeUtils.js.map +0 -1
- package/dist/esm/shared/lib/session.d.ts +0 -4
- package/dist/esm/shared/lib/session.d.ts.map +0 -1
- package/dist/esm/shared/lib/session.js.map +0 -1
- package/dist/esm/shared/lib/storage.d.ts +0 -34
- package/dist/esm/shared/lib/storage.d.ts.map +0 -1
- package/dist/esm/shared/lib/storage.js.map +0 -1
- package/dist/esm/shared/lib/types.d.ts +0 -38
- package/dist/esm/shared/lib/types.d.ts.map +0 -1
- package/dist/esm/shared/lib/types.js.map +0 -1
- package/dist/esm/shared/lib/util.d.ts +0 -37
- package/dist/esm/shared/lib/util.d.ts.map +0 -1
- package/dist/esm/shared/lib/util.js +0 -155
- package/dist/esm/shared/lib/util.js.map +0 -1
- package/dist/esm/shared/providers/AuthContext.d.ts +0 -12
- package/dist/esm/shared/providers/AuthContext.d.ts.map +0 -1
- package/dist/esm/shared/providers/AuthContext.js.map +0 -1
- package/dist/esm/shared/providers/AuthProvider.d.ts +0 -22
- package/dist/esm/shared/providers/AuthProvider.d.ts.map +0 -1
- package/dist/esm/shared/providers/AuthProvider.js +0 -72
- package/dist/esm/shared/providers/AuthProvider.js.map +0 -1
- package/dist/esm/shared/providers/CivicAuthConfigContext.d.ts +0 -19
- package/dist/esm/shared/providers/CivicAuthConfigContext.d.ts.map +0 -1
- package/dist/esm/shared/providers/CivicAuthConfigContext.js.map +0 -1
- package/dist/esm/shared/providers/CivicAuthProvider.d.ts +0 -6
- package/dist/esm/shared/providers/CivicAuthProvider.d.ts.map +0 -1
- package/dist/esm/shared/providers/CivicAuthProvider.js +0 -32
- package/dist/esm/shared/providers/CivicAuthProvider.js.map +0 -1
- package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.d.ts +0 -17
- package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.d.ts.map +0 -1
- package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.js +0 -131
- package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.js.map +0 -1
- package/dist/esm/shared/providers/IframeProvider.d.ts +0 -24
- package/dist/esm/shared/providers/IframeProvider.d.ts.map +0 -1
- package/dist/esm/shared/providers/IframeProvider.js +0 -41
- package/dist/esm/shared/providers/IframeProvider.js.map +0 -1
- package/dist/esm/shared/providers/SessionProvider.d.ts +0 -19
- package/dist/esm/shared/providers/SessionProvider.d.ts.map +0 -1
- package/dist/esm/shared/providers/SessionProvider.js.map +0 -1
- package/dist/esm/shared/providers/TokenProvider.d.ts +0 -17
- package/dist/esm/shared/providers/TokenProvider.d.ts.map +0 -1
- package/dist/esm/shared/providers/TokenProvider.js.map +0 -1
- package/dist/esm/shared/providers/UserProvider.d.ts +0 -26
- package/dist/esm/shared/providers/UserProvider.d.ts.map +0 -1
- package/dist/esm/shared/providers/UserProvider.js.map +0 -1
- package/dist/esm/shared/providers/types.d.ts +0 -15
- package/dist/esm/shared/providers/types.d.ts.map +0 -1
- package/dist/esm/shared/providers/types.js.map +0 -1
- package/dist/esm/shared/version.d.ts +0 -2
- package/dist/esm/shared/version.d.ts.map +0 -1
- package/dist/esm/shared/version.js +0 -3
- package/dist/esm/shared/version.js.map +0 -1
- package/dist/esm/types.d.ts +0 -159
- package/dist/esm/types.d.ts.map +0 -1
- package/dist/esm/types.js.map +0 -1
- package/dist/esm/utils.d.ts +0 -15
- package/dist/esm/utils.d.ts.map +0 -1
- package/dist/esm/utils.js.map +0 -1
- package/dist/esm/version.d.ts +0 -2
- package/dist/esm/version.d.ts.map +0 -1
- package/dist/esm/version.js.map +0 -1
- package/dist/tsconfig.cjs.tsbuildinfo +0 -1
- package/dist/tsconfig.esm.tsbuildinfo +0 -1
- /package/dist/{cjs/browser → browser}/storage.d.ts +0 -0
- /package/dist/{esm/browser → browser}/storage.js +0 -0
- /package/dist/{cjs/config.d.ts → config.d.ts} +0 -0
- /package/dist/{esm/config.js → config.js} +0 -0
- /package/dist/{cjs/index.d.ts → index.d.ts} +0 -0
- /package/dist/{esm/index.js → index.js} +0 -0
- /package/dist/{cjs/lib → lib}/cookies.d.ts +0 -0
- /package/dist/{esm/lib → lib}/cookies.js +0 -0
- /package/dist/{cjs/lib → lib}/jwt.d.ts +0 -0
- /package/dist/{esm/lib → lib}/jwt.js +0 -0
- /package/dist/{cjs/lib → lib}/logger.d.ts +0 -0
- /package/dist/{esm/lib → lib}/logger.js +0 -0
- /package/dist/{cjs/lib → lib}/oauth.d.ts +0 -0
- /package/dist/{esm/lib → lib}/oauth.js +0 -0
- /package/dist/{cjs/lib → lib}/obj.d.ts +0 -0
- /package/dist/{esm/lib → lib}/obj.js +0 -0
- /package/dist/{cjs/lib → lib}/postMessage.d.ts +0 -0
- /package/dist/{cjs/lib → lib}/windowUtil.d.ts +0 -0
- /package/dist/{esm/lib → lib}/windowUtil.js +0 -0
- /package/dist/{cjs/nextjs → nextjs}/NextClientAuthenticationRefresher.d.ts +0 -0
- /package/dist/{esm/nextjs → nextjs}/NextClientAuthenticationRefresher.js +0 -0
- /package/dist/{esm/nextjs → nextjs}/config.d.ts +0 -0
- /package/dist/{esm/nextjs → nextjs}/config.js +0 -0
- /package/dist/{cjs/nextjs → nextjs}/hooks/index.d.ts +0 -0
- /package/dist/{esm/nextjs → nextjs}/hooks/index.js +0 -0
- /package/dist/{cjs/nextjs → nextjs}/hooks/usePrevious.d.ts +0 -0
- /package/dist/{esm/nextjs → nextjs}/hooks/usePrevious.js +0 -0
- /package/dist/{cjs/nextjs → nextjs}/hooks/useRefresh.d.ts +0 -0
- /package/dist/{esm/nextjs → nextjs}/hooks/useRefresh.js +0 -0
- /package/dist/{cjs/nextjs → nextjs}/hooks/useUserCookie.d.ts +0 -0
- /package/dist/{esm/nextjs → nextjs}/hooks/useUserCookie.js +0 -0
- /package/dist/{cjs/nextjs → nextjs}/index.d.ts +0 -0
- /package/dist/{esm/nextjs → nextjs}/index.js +0 -0
- /package/dist/{cjs/nextjs → nextjs}/middleware/index.d.ts +0 -0
- /package/dist/{esm/nextjs → nextjs}/middleware/index.js +0 -0
- /package/dist/{cjs/nextjs → nextjs}/middleware.d.ts +0 -0
- /package/dist/{cjs/nextjs → nextjs}/providers/NextAuthProvider.d.ts +0 -0
- /package/dist/{esm/nextjs → nextjs}/providers/NextAuthProvider.js +0 -0
- /package/dist/{cjs/nextjs → nextjs}/routeHandler.d.ts +0 -0
- /package/dist/{cjs/nextjs → nextjs}/utils.d.ts +0 -0
- /package/dist/{esm/nextjs → nextjs}/utils.js +0 -0
- /package/dist/{cjs/reactjs → reactjs}/components/ButtonContentOrLoader.d.ts +0 -0
- /package/dist/{esm/reactjs → reactjs}/components/ButtonContentOrLoader.js +0 -0
- /package/dist/{cjs/reactjs → reactjs}/components/SignInButton.d.ts +0 -0
- /package/dist/{esm/reactjs → reactjs}/components/SignInButton.js +0 -0
- /package/dist/{cjs/reactjs → reactjs}/components/SignOutButton.d.ts +0 -0
- /package/dist/{esm/reactjs → reactjs}/components/SignOutButton.js +0 -0
- /package/dist/{cjs/reactjs → reactjs}/components/UserButton.d.ts +0 -0
- /package/dist/{cjs/reactjs → reactjs}/components/index.d.ts +0 -0
- /package/dist/{esm/reactjs → reactjs}/components/index.js +0 -0
- /package/dist/{cjs/reactjs → reactjs}/components/utils.d.ts +0 -0
- /package/dist/{esm/reactjs → reactjs}/components/utils.js +0 -0
- /package/dist/{cjs/reactjs → reactjs}/hooks/index.d.ts +0 -0
- /package/dist/{esm/reactjs → reactjs}/hooks/index.js +0 -0
- /package/dist/{cjs/reactjs → reactjs}/hooks/useClientTokenExchangeSession.d.ts +0 -0
- /package/dist/{esm/reactjs → reactjs}/hooks/useClientTokenExchangeSession.js +0 -0
- /package/dist/{cjs/reactjs → reactjs}/hooks/useUser.d.ts +0 -0
- /package/dist/{esm/reactjs → reactjs}/hooks/useUser.js +0 -0
- /package/dist/{cjs/reactjs → reactjs}/index.d.ts +0 -0
- /package/dist/{esm/reactjs → reactjs}/index.js +0 -0
- /package/dist/{cjs/reactjs → reactjs}/providers/AuthProvider.d.ts +0 -0
- /package/dist/{esm/reactjs → reactjs}/providers/AuthProvider.js +0 -0
- /package/dist/{cjs/reactjs → reactjs}/providers/CivicAuthProvider.d.ts +0 -0
- /package/dist/{esm/reactjs → reactjs}/providers/CivicAuthProvider.js +0 -0
- /package/dist/{cjs/reactjs → reactjs}/providers/ClientTokenExchangeSessionProvider.d.ts +0 -0
- /package/dist/{esm/reactjs → reactjs}/providers/ClientTokenExchangeSessionProvider.js +0 -0
- /package/dist/{cjs/reactjs → reactjs}/providers/index.d.ts +0 -0
- /package/dist/{esm/reactjs → reactjs}/providers/index.js +0 -0
- /package/dist/{cjs/server → server}/ServerAuthenticationResolver.d.ts +0 -0
- /package/dist/{cjs/server → server}/config.d.ts +0 -0
- /package/dist/{esm/server → server}/config.js +0 -0
- /package/dist/{cjs/server → server}/index.d.ts +0 -0
- /package/dist/{esm/server → server}/index.js +0 -0
- /package/dist/{cjs/server → server}/login.d.ts +0 -0
- /package/dist/{esm/server → server}/login.js +0 -0
- /package/dist/{cjs/server → server}/logout.d.ts +0 -0
- /package/dist/{esm/server → server}/logout.js +0 -0
- /package/dist/{cjs/server → server}/refresh.d.ts +0 -0
- /package/dist/{esm/server → server}/refresh.js +0 -0
- /package/dist/{cjs/services → services}/PKCE.d.ts +0 -0
- /package/dist/{esm/services → services}/PKCE.js +0 -0
- /package/dist/{cjs/services → services}/types.d.ts +0 -0
- /package/dist/{esm/services → services}/types.js +0 -0
- /package/dist/{cjs/shared → shared}/components/BlockDisplay.d.ts +0 -0
- /package/dist/{cjs/shared → shared}/components/CivicAuthIframe.d.ts +0 -0
- /package/dist/{cjs/shared → shared}/components/CivicAuthIframeContainer.d.ts +0 -0
- /package/dist/{cjs/shared → shared}/components/CivicAuthLogoutIframeContainer.d.ts +0 -0
- /package/dist/{cjs/shared → shared}/components/CloseIcon.d.ts +0 -0
- /package/dist/{esm/shared → shared}/components/CloseIcon.js +0 -0
- /package/dist/{cjs/shared → shared}/components/IFrameAndLoading.d.ts +0 -0
- /package/dist/{esm/shared → shared}/components/IFrameAndLoading.js +0 -0
- /package/dist/{cjs/shared → shared}/components/LoadingIcon.d.ts +0 -0
- /package/dist/{esm/shared → shared}/components/LoadingIcon.js +0 -0
- /package/dist/{cjs/shared → shared}/hooks/index.d.ts +0 -0
- /package/dist/{esm/shared → shared}/hooks/index.js +0 -0
- /package/dist/{cjs/reactjs → shared}/hooks/useAuth.d.ts +0 -0
- /package/dist/{esm/reactjs → shared}/hooks/useAuth.js +0 -0
- /package/dist/{esm/shared → shared}/hooks/useCivicAuthConfig.d.ts +0 -0
- /package/dist/{esm/shared → shared}/hooks/useCivicAuthConfig.js +0 -0
- /package/dist/{cjs/shared → shared}/hooks/useCurrentUrl.d.ts +0 -0
- /package/dist/{esm/shared → shared}/hooks/useCurrentUrl.js +0 -0
- /package/dist/{cjs/shared → shared}/hooks/useIframe.d.ts +0 -0
- /package/dist/{esm/shared → shared}/hooks/useIframe.js +0 -0
- /package/dist/{cjs/shared → shared}/hooks/useIsInIframe.d.ts +0 -0
- /package/dist/{esm/shared → shared}/hooks/useIsInIframe.js +0 -0
- /package/dist/{cjs/shared → shared}/hooks/useOAuthEndpoints.d.ts +0 -0
- /package/dist/{esm/shared → shared}/hooks/useOAuthEndpoints.js +0 -0
- /package/dist/{cjs/shared → shared}/hooks/useRefresh.d.ts +0 -0
- /package/dist/{esm/shared → shared}/hooks/useRefresh.js +0 -0
- /package/dist/{cjs/shared → shared}/hooks/useSession.d.ts +0 -0
- /package/dist/{esm/shared → shared}/hooks/useSession.js +0 -0
- /package/dist/{cjs/shared → shared}/hooks/useSignIn.d.ts +0 -0
- /package/dist/{cjs/shared → shared}/hooks/useToken.d.ts +0 -0
- /package/dist/{esm/shared → shared}/hooks/useToken.js +0 -0
- /package/dist/{cjs/shared → shared}/hooks/useWindowFocused.d.ts +0 -0
- /package/dist/{esm/shared → shared}/hooks/useWindowFocused.js +0 -0
- /package/dist/{cjs/shared → shared}/index.d.ts +0 -0
- /package/dist/{esm/shared → shared}/index.js +0 -0
- /package/dist/{cjs/shared → shared}/lib/GenericAuthenticationRefresher.d.ts +0 -0
- /package/dist/{esm/shared → shared}/lib/GenericAuthenticationRefresher.js +0 -0
- /package/dist/{cjs/shared → shared}/lib/UserSession.d.ts +0 -0
- /package/dist/{esm/shared → shared}/lib/UserSession.js +0 -0
- /package/dist/{cjs/shared → shared}/lib/iframeUtils.d.ts +0 -0
- /package/dist/{esm/shared → shared}/lib/iframeUtils.js +0 -0
- /package/dist/{cjs/shared → shared}/lib/session.d.ts +0 -0
- /package/dist/{esm/shared → shared}/lib/session.js +0 -0
- /package/dist/{esm/shared → shared}/lib/storage.js +0 -0
- /package/dist/{esm/shared → shared}/lib/types.js +0 -0
- /package/dist/{cjs/shared → shared}/providers/AuthContext.d.ts +0 -0
- /package/dist/{esm/shared → shared}/providers/AuthContext.js +0 -0
- /package/dist/{cjs/shared → shared}/providers/CivicAuthConfigContext.d.ts +0 -0
- /package/dist/{esm/shared → shared}/providers/CivicAuthConfigContext.js +0 -0
- /package/dist/{cjs/shared → shared}/providers/SessionProvider.d.ts +0 -0
- /package/dist/{esm/shared → shared}/providers/SessionProvider.js +0 -0
- /package/dist/{cjs/shared → shared}/providers/TokenProvider.d.ts +0 -0
- /package/dist/{esm/shared → shared}/providers/TokenProvider.js +0 -0
- /package/dist/{cjs/shared → shared}/providers/UserProvider.d.ts +0 -0
- /package/dist/{esm/shared → shared}/providers/UserProvider.js +0 -0
- /package/dist/{cjs/shared → shared}/providers/types.d.ts +0 -0
- /package/dist/{esm/shared → shared}/providers/types.js +0 -0
- /package/dist/{esm/types.js → types.js} +0 -0
- /package/dist/{cjs/utils.d.ts → utils.d.ts} +0 -0
- /package/dist/{esm/utils.js → utils.js} +0 -0
- /package/dist/{cjs/version.d.ts → version.d.ts} +0 -0
- /package/dist/{esm/version.js → version.js} +0 -0
|
@@ -1,65 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.GenericAuthenticationRefresher = void 0;
|
|
4
|
-
const constants_js_1 = require("../../constants.js");
|
|
5
|
-
const util_js_1 = require("../../shared/lib/util.js");
|
|
6
|
-
class GenericAuthenticationRefresher {
|
|
7
|
-
authConfig;
|
|
8
|
-
storage;
|
|
9
|
-
static refreshInProgress = false;
|
|
10
|
-
get oauthServer() {
|
|
11
|
-
return this.authConfig?.oauthServer || constants_js_1.DEFAULT_AUTH_SERVER;
|
|
12
|
-
}
|
|
13
|
-
async getRefreshToken() {
|
|
14
|
-
if (!this.storage)
|
|
15
|
-
throw new Error("No storage available");
|
|
16
|
-
const tokens = await (0, util_js_1.retrieveTokens)(this.storage);
|
|
17
|
-
if (!tokens?.refresh_token)
|
|
18
|
-
throw new Error("No refresh token available");
|
|
19
|
-
return tokens.refresh_token;
|
|
20
|
-
}
|
|
21
|
-
async refreshTokens() {
|
|
22
|
-
return this.refreshAccessToken();
|
|
23
|
-
}
|
|
24
|
-
async handleRefresh() {
|
|
25
|
-
try {
|
|
26
|
-
// ensure only one refresh is in progress
|
|
27
|
-
if (localStorage.getItem(constants_js_1.REFRESH_IN_PROGRESS) !== "true") {
|
|
28
|
-
localStorage.setItem(constants_js_1.REFRESH_IN_PROGRESS, "true");
|
|
29
|
-
await this.refreshTokens();
|
|
30
|
-
localStorage.setItem(constants_js_1.REFRESH_IN_PROGRESS, "false");
|
|
31
|
-
await this.setupAutorefresh(); // Reset the timeout after successful refresh
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
catch (error) {
|
|
35
|
-
console.error("Failed to refresh tokens:", error);
|
|
36
|
-
// TODO detect if refresh token has expired and if yes then logout
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
async setupAutorefresh() {
|
|
40
|
-
if (!this.storage)
|
|
41
|
-
throw new Error("No storage available");
|
|
42
|
-
// Clear any existing timeout
|
|
43
|
-
this.clearAutorefresh();
|
|
44
|
-
// get expires_in
|
|
45
|
-
const now = Math.floor(Date.now() / 1000);
|
|
46
|
-
const expiresAt = (await (0, util_js_1.retrieveAccessTokenExpiresAt)(this.storage)) || now + 60;
|
|
47
|
-
// Calculate time until expiry (subtract 30 seconds as buffer)
|
|
48
|
-
const bufferTime = 30; // 30 seconds
|
|
49
|
-
const refreshTime = Math.max(0, expiresAt - bufferTime - now); // handle case were token has expired in the past
|
|
50
|
-
const refreshTimeout = setTimeout(() => {
|
|
51
|
-
this.handleRefresh();
|
|
52
|
-
}, 1000 * refreshTime);
|
|
53
|
-
localStorage.setItem(constants_js_1.AUTOREFRESH_TIMEOUT_NAME, refreshTimeout.toString());
|
|
54
|
-
}
|
|
55
|
-
clearAutorefresh() {
|
|
56
|
-
// use local storage to store the timeout id so that if multiple instances
|
|
57
|
-
// of the refresher are created they can all clear the same timeout
|
|
58
|
-
const existingTimeout = localStorage.getItem(constants_js_1.AUTOREFRESH_TIMEOUT_NAME);
|
|
59
|
-
if (existingTimeout) {
|
|
60
|
-
clearTimeout(existingTimeout);
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
exports.GenericAuthenticationRefresher = GenericAuthenticationRefresher;
|
|
65
|
-
//# sourceMappingURL=GenericAuthenticationRefresher.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"GenericAuthenticationRefresher.js","sourceRoot":"","sources":["../../../../src/shared/lib/GenericAuthenticationRefresher.ts"],"names":[],"mappings":";;;AAAA,iDAIwB;AAGxB,kDAG8B;AAG9B,MAAsB,8BAA8B;IAGxC,UAAU,CAAyB;IACnC,OAAO,CAA0B;IAC3C,MAAM,CAAC,iBAAiB,GAAG,KAAK,CAAC;IAEjC,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,UAAU,EAAE,WAAW,IAAI,kCAAmB,CAAC;IAC7D,CAAC;IAMD,KAAK,CAAC,eAAe;QACnB,IAAI,CAAC,IAAI,CAAC,OAAO;YAAE,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAC;QAE3D,MAAM,MAAM,GAAG,MAAM,IAAA,wBAAc,EAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAClD,IAAI,CAAC,MAAM,EAAE,aAAa;YAAE,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAC;QAC1E,OAAO,MAAM,CAAC,aAAa,CAAC;IAC9B,CAAC;IAED,KAAK,CAAC,aAAa;QACjB,OAAO,IAAI,CAAC,kBAAkB,EAAE,CAAC;IACnC,CAAC;IAEO,KAAK,CAAC,aAAa;QACzB,IAAI,CAAC;YACH,yCAAyC;YACzC,IAAI,YAAY,CAAC,OAAO,CAAC,kCAAmB,CAAC,KAAK,MAAM,EAAE,CAAC;gBACzD,YAAY,CAAC,OAAO,CAAC,kCAAmB,EAAE,MAAM,CAAC,CAAC;gBAClD,MAAM,IAAI,CAAC,aAAa,EAAE,CAAC;gBAC3B,YAAY,CAAC,OAAO,CAAC,kCAAmB,EAAE,OAAO,CAAC,CAAC;gBACnD,MAAM,IAAI,CAAC,gBAAgB,EAAE,CAAC,CAAC,6CAA6C;YAC9E,CAAC;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CAAC,2BAA2B,EAAE,KAAK,CAAC,CAAC;YAClD,kEAAkE;QACpE,CAAC;IACH,CAAC;IAED,KAAK,CAAC,gBAAgB;QACpB,IAAI,CAAC,IAAI,CAAC,OAAO;YAAE,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAC;QAC3D,6BAA6B;QAC7B,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAExB,iBAAiB;QACjB,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,CAAC;QAC1C,MAAM,SAAS,GACb,CAAC,MAAM,IAAA,sCAA4B,EAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,GAAG,GAAG,EAAE,CAAC;QAEjE,8DAA8D;QAC9D,MAAM,UAAU,GAAG,EAAE,CAAC,CAAC,aAAa;QACpC,MAAM,WAAW,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,SAAS,GAAG,UAAU,GAAG,GAAG,CAAC,CAAC,CAAC,iDAAiD;QAEhH,MAAM,cAAc,GAAG,UAAU,CAAC,GAAG,EAAE;YACrC,IAAI,CAAC,aAAa,EAAE,CAAC;QACvB,CAAC,EAAE,IAAI,GAAG,WAAW,CAAC,CAAC;QACvB,YAAY,CAAC,OAAO,CAAC,uCAAwB,EAAE,cAAc,CAAC,QAAQ,EAAE,CAAC,CAAC;IAC5E,CAAC;IAED,gBAAgB;QACd,0EAA0E;QAC1E,mEAAmE;QACnE,MAAM,eAAe,GAAG,YAAY,CAAC,OAAO,CAAC,uCAAwB,CAAC,CAAC;QACvE,IAAI,eAAe,EAAE,CAAC;YACpB,YAAY,CAAC,eAAe,CAAC,CAAC;QAChC,CAAC;IACH,CAAC;;AArEH,wEAsEC","sourcesContent":["import {\n AUTOREFRESH_TIMEOUT_NAME,\n DEFAULT_AUTH_SERVER,\n REFRESH_IN_PROGRESS,\n} from \"@/constants.js\";\nimport type { AuthConfig } from \"@/server/config.js\";\nimport type { AuthenticationRefresher } from \"@/services/types.js\";\nimport {\n retrieveAccessTokenExpiresAt,\n retrieveTokens,\n} from \"@/shared/lib/util.js\";\nimport type { AuthStorage, OIDCTokenResponseBody } from \"@/types.js\";\n\nexport abstract class GenericAuthenticationRefresher\n implements AuthenticationRefresher\n{\n protected authConfig: AuthConfig | undefined;\n protected storage: AuthStorage | undefined;\n static refreshInProgress = false;\n\n get oauthServer(): string {\n return this.authConfig?.oauthServer || DEFAULT_AUTH_SERVER;\n }\n\n abstract refreshAccessToken(\n refreshToken?: string,\n ): Promise<OIDCTokenResponseBody>;\n\n async getRefreshToken(): Promise<string> {\n if (!this.storage) throw new Error(\"No storage available\");\n\n const tokens = await retrieveTokens(this.storage);\n if (!tokens?.refresh_token) throw new Error(\"No refresh token available\");\n return tokens.refresh_token;\n }\n\n async refreshTokens() {\n return this.refreshAccessToken();\n }\n\n private async handleRefresh() {\n try {\n // ensure only one refresh is in progress\n if (localStorage.getItem(REFRESH_IN_PROGRESS) !== \"true\") {\n localStorage.setItem(REFRESH_IN_PROGRESS, \"true\");\n await this.refreshTokens();\n localStorage.setItem(REFRESH_IN_PROGRESS, \"false\");\n await this.setupAutorefresh(); // Reset the timeout after successful refresh\n }\n } catch (error) {\n console.error(\"Failed to refresh tokens:\", error);\n // TODO detect if refresh token has expired and if yes then logout\n }\n }\n\n async setupAutorefresh() {\n if (!this.storage) throw new Error(\"No storage available\");\n // Clear any existing timeout\n this.clearAutorefresh();\n\n // get expires_in\n const now = Math.floor(Date.now() / 1000);\n const expiresAt =\n (await retrieveAccessTokenExpiresAt(this.storage)) || now + 60;\n\n // Calculate time until expiry (subtract 30 seconds as buffer)\n const bufferTime = 30; // 30 seconds\n const refreshTime = Math.max(0, expiresAt - bufferTime - now); // handle case were token has expired in the past\n\n const refreshTimeout = setTimeout(() => {\n this.handleRefresh();\n }, 1000 * refreshTime);\n localStorage.setItem(AUTOREFRESH_TIMEOUT_NAME, refreshTimeout.toString());\n }\n\n clearAutorefresh() {\n // use local storage to store the timeout id so that if multiple instances\n // of the refresher are created they can all clear the same timeout\n const existingTimeout = localStorage.getItem(AUTOREFRESH_TIMEOUT_NAME);\n if (existingTimeout) {\n clearTimeout(existingTimeout);\n }\n }\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"UserSession.d.ts","sourceRoot":"","sources":["../../../../src/shared/lib/UserSession.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,WAAW,EACX,kBAAkB,EAClB,aAAa,EACb,IAAI,EACL,MAAM,YAAY,CAAC;AAIpB,MAAM,WAAW,WAAW,CAAC,CAAC,SAAS,aAAa;IAClD,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC;IAC/B,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,GAAG;QAAE,eAAe,CAAC,EAAE,kBAAkB,CAAA;KAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CAC9E;AAED,qBAAa,kBAAkB,CAAC,CAAC,SAAS,aAAa,CACrD,YAAW,WAAW,CAAC,CAAC,CAAC;IAEb,QAAQ,CAAC,OAAO,EAAE,WAAW;gBAApB,OAAO,EAAE,WAAW;IAEnC,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;IAK9B,GAAG,CACP,IAAI,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG;QAAE,eAAe,CAAC,EAAE,kBAAkB,CAAA;KAAE,CAAC,GAAG,IAAI,GAChE,OAAO,CAAC,IAAI,CAAC;IAQV,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;CAG7B"}
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.GenericUserSession = void 0;
|
|
4
|
-
const types_js_1 = require("../../shared/lib/types.js");
|
|
5
|
-
const jwt_js_1 = require("../../lib/jwt.js");
|
|
6
|
-
class GenericUserSession {
|
|
7
|
-
storage;
|
|
8
|
-
constructor(storage) {
|
|
9
|
-
this.storage = storage;
|
|
10
|
-
}
|
|
11
|
-
async get() {
|
|
12
|
-
const user = await this.storage.get(types_js_1.UserStorage.USER);
|
|
13
|
-
return user ? JSON.parse(user) : null;
|
|
14
|
-
}
|
|
15
|
-
async set(user) {
|
|
16
|
-
const forwardedTokens = user?.forwardedTokens
|
|
17
|
-
? (0, jwt_js_1.convertForwardedTokenFormat)(user?.forwardedTokens)
|
|
18
|
-
: null;
|
|
19
|
-
const value = user ? JSON.stringify({ ...user, forwardedTokens }) : "";
|
|
20
|
-
await this.storage.set(types_js_1.UserStorage.USER, value);
|
|
21
|
-
}
|
|
22
|
-
async clear() {
|
|
23
|
-
await this.storage.delete(types_js_1.UserStorage.USER);
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
exports.GenericUserSession = GenericUserSession;
|
|
27
|
-
//# sourceMappingURL=UserSession.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"UserSession.js","sourceRoot":"","sources":["../../../../src/shared/lib/UserSession.ts"],"names":[],"mappings":";;;AAMA,oDAAoD;AACpD,yCAA2D;AAO3D,MAAa,kBAAkB;IAGR;IAArB,YAAqB,OAAoB;QAApB,YAAO,GAAP,OAAO,CAAa;IAAG,CAAC;IAE7C,KAAK,CAAC,GAAG;QACP,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,sBAAW,CAAC,IAAI,CAAC,CAAC;QACtD,OAAO,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IACxC,CAAC;IAED,KAAK,CAAC,GAAG,CACP,IAAiE;QAEjE,MAAM,eAAe,GAAG,IAAI,EAAE,eAAe;YAC3C,CAAC,CAAC,IAAA,oCAA2B,EAAC,IAAI,EAAE,eAAqC,CAAC;YAC1E,CAAC,CAAC,IAAI,CAAC;QACT,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,GAAG,IAAI,EAAE,eAAe,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QACvE,MAAM,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,sBAAW,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;IAClD,CAAC;IAED,KAAK,CAAC,KAAK;QACT,MAAM,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,sBAAW,CAAC,IAAI,CAAC,CAAC;IAC9C,CAAC;CACF;AAvBD,gDAuBC","sourcesContent":["import type {\n AuthStorage,\n ForwardedTokensJWT,\n UnknownObject,\n User,\n} from \"@/types.js\";\nimport { UserStorage } from \"@/shared/lib/types.js\";\nimport { convertForwardedTokenFormat } from \"@/lib/jwt.js\";\n\nexport interface UserSession<T extends UnknownObject> {\n get(): Promise<User<T> | null>;\n set(user: User<T> & { forwardedTokens?: ForwardedTokensJWT }): Promise<void>;\n}\n\nexport class GenericUserSession<T extends UnknownObject>\n implements UserSession<T>\n{\n constructor(readonly storage: AuthStorage) {}\n\n async get(): Promise<User<T> | null> {\n const user = await this.storage.get(UserStorage.USER);\n return user ? JSON.parse(user) : null;\n }\n\n async set(\n user: (User<T> & { forwardedTokens?: ForwardedTokensJWT }) | null,\n ): Promise<void> {\n const forwardedTokens = user?.forwardedTokens\n ? convertForwardedTokenFormat(user?.forwardedTokens as ForwardedTokensJWT)\n : null;\n const value = user ? JSON.stringify({ ...user, forwardedTokens }) : \"\";\n await this.storage.set(UserStorage.USER, value);\n }\n\n async clear(): Promise<void> {\n await this.storage.delete(UserStorage.USER);\n }\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"iframeUtils.d.ts","sourceRoot":"","sources":["../../../../src/shared/lib/iframeUtils.ts"],"names":[],"mappings":"AAAA,KAAK,qBAAqB,GAAG,iBAAiB,GAAG;IAC/C,UAAU,EAAE,MAAM,iBAAiB,CAAC;CACrC,CAAC;AACF,eAAO,MAAM,YAAY,cACZ,iBAAiB,GAAG,qBAAqB,GAAG,IAAI,KAC1D,iBAKF,CAAC"}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.getIframeRef = void 0;
|
|
4
|
-
const getIframeRef = (iframeRef) => {
|
|
5
|
-
if (!iframeRef) {
|
|
6
|
-
throw new Error("iframeRef is required for displayMode 'iframe'");
|
|
7
|
-
}
|
|
8
|
-
return iframeRef?.getElement?.() ?? iframeRef;
|
|
9
|
-
};
|
|
10
|
-
exports.getIframeRef = getIframeRef;
|
|
11
|
-
//# sourceMappingURL=iframeUtils.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"iframeUtils.js","sourceRoot":"","sources":["../../../../src/shared/lib/iframeUtils.ts"],"names":[],"mappings":";;;AAGO,MAAM,YAAY,GAAG,CAC1B,SAA2D,EACxC,EAAE;IACrB,IAAI,CAAC,SAAS,EAAE,CAAC;QACf,MAAM,IAAI,KAAK,CAAC,gDAAgD,CAAC,CAAC;IACpE,CAAC;IACD,OAAQ,SAAmC,EAAE,UAAU,EAAE,EAAE,IAAI,SAAS,CAAC;AAC3E,CAAC,CAAC;AAPW,QAAA,YAAY,gBAOvB","sourcesContent":["type ExtendedIframeElement = HTMLIFrameElement & {\n getElement: () => HTMLIFrameElement;\n};\nexport const getIframeRef = (\n iframeRef: HTMLIFrameElement | ExtendedIframeElement | null,\n): HTMLIFrameElement => {\n if (!iframeRef) {\n throw new Error(\"iframeRef is required for displayMode 'iframe'\");\n }\n return (iframeRef as ExtendedIframeElement)?.getElement?.() ?? iframeRef;\n};\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"session.d.ts","sourceRoot":"","sources":["../../../../src/shared/lib/session.ts"],"names":[],"mappings":"AAEA,OAAO,EAEL,KAAK,WAAW,EAChB,KAAK,WAAW,EAChB,KAAK,IAAI,EACT,KAAK,WAAW,EAChB,KAAK,aAAa,EACnB,MAAM,YAAY,CAAC;AAsBpB,wBAAsB,OAAO,CAAC,CAAC,SAAS,aAAa,GAAG,WAAW,EACjE,OAAO,EAAE,WAAW,GACnB,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAoBzB;AAED,wBAAsB,SAAS,CAC7B,OAAO,EAAE,WAAW,GACnB,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC,CAS7B"}
|
|
@@ -1,48 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.getUser = getUser;
|
|
4
|
-
exports.getTokens = getTokens;
|
|
5
|
-
const util_js_1 = require("../../shared/lib/util.js");
|
|
6
|
-
const jose_1 = require("jose");
|
|
7
|
-
const types_js_1 = require("../../types.js");
|
|
8
|
-
const constants_js_1 = require("../../constants.js");
|
|
9
|
-
// Function to omit keys from an object
|
|
10
|
-
const omitKeys = (keys, obj) => {
|
|
11
|
-
const result = { ...obj };
|
|
12
|
-
keys.forEach((key) => {
|
|
13
|
-
delete result[key];
|
|
14
|
-
});
|
|
15
|
-
return result;
|
|
16
|
-
};
|
|
17
|
-
const parseJWTToType = (jwt) => {
|
|
18
|
-
const parseResult = (0, jose_1.decodeJwt)(jwt);
|
|
19
|
-
return parseResult;
|
|
20
|
-
};
|
|
21
|
-
async function getUser(storage) {
|
|
22
|
-
const tokens = await (0, util_js_1.retrieveTokens)(storage);
|
|
23
|
-
if (!tokens)
|
|
24
|
-
return null;
|
|
25
|
-
const parsedToken = parseJWTToType(tokens.id_token);
|
|
26
|
-
// it might be preferable to throw here
|
|
27
|
-
if (!parsedToken.sub)
|
|
28
|
-
return null;
|
|
29
|
-
// set the user ID from the token sub
|
|
30
|
-
const userWithAdditionalTokenFields = {
|
|
31
|
-
...parsedToken,
|
|
32
|
-
id: parsedToken.sub,
|
|
33
|
-
};
|
|
34
|
-
// Assumes all information is in the ID token
|
|
35
|
-
// remove the token keys from the user object to stop it getting too large
|
|
36
|
-
return omitKeys([...constants_js_1.JWT_PAYLOAD_KNOWN_CLAIM_KEYS, ...types_js_1.tokenKeys], userWithAdditionalTokenFields);
|
|
37
|
-
}
|
|
38
|
-
async function getTokens(storage) {
|
|
39
|
-
const storageData = await (0, util_js_1.retrieveTokens)(storage);
|
|
40
|
-
if (!storageData)
|
|
41
|
-
return null;
|
|
42
|
-
return {
|
|
43
|
-
idToken: storageData.id_token,
|
|
44
|
-
accessToken: storageData.access_token,
|
|
45
|
-
refreshToken: storageData.refresh_token,
|
|
46
|
-
};
|
|
47
|
-
}
|
|
48
|
-
//# sourceMappingURL=session.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"session.js","sourceRoot":"","sources":["../../../../src/shared/lib/session.ts"],"names":[],"mappings":";;AA+BA,0BAsBC;AAED,8BAWC;AAlED,kDAAsD;AACtD,+BAAkD;AAClD,yCAOoB;AACpB,iDAA8D;AAE9D,uCAAuC;AACvC,MAAM,QAAQ,GAAG,CACf,IAAS,EACT,GAAM,EACM,EAAE;IACd,MAAM,MAAM,GAAG,EAAE,GAAG,GAAG,EAAE,CAAC;IAC1B,IAAI,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE;QACnB,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC;IACrB,CAAC,CAAC,CAAC;IACH,OAAO,MAAM,CAAC;AAChB,CAAC,CAAC;AAEF,MAAM,cAAc,GAAG,CACrB,GAAW,EACK,EAAE;IAClB,MAAM,WAAW,GAAG,IAAA,gBAAS,EAAC,GAAG,CAAC,CAAC;IACnC,OAAO,WAA6B,CAAC;AACvC,CAAC,CAAC;AAEK,KAAK,UAAU,OAAO,CAC3B,OAAoB;IAEpB,MAAM,MAAM,GAAG,MAAM,IAAA,wBAAc,EAAC,OAAO,CAAC,CAAC;IAC7C,IAAI,CAAC,MAAM;QAAE,OAAO,IAAI,CAAC;IAEzB,MAAM,WAAW,GAAG,cAAc,CAAI,MAAM,CAAC,QAAQ,CAAC,CAAC;IACvD,uCAAuC;IACvC,IAAI,CAAC,WAAW,CAAC,GAAG;QAAE,OAAO,IAAI,CAAC;IAElC,qCAAqC;IACrC,MAAM,6BAA6B,GAAG;QACpC,GAAI,WAAiB;QACrB,EAAE,EAAE,WAAW,CAAC,GAAG;KACpB,CAAC;IAEF,6CAA6C;IAC7C,0EAA0E;IAC1E,OAAO,QAAQ,CACb,CAAC,GAAG,2CAA4B,EAAE,GAAG,oBAAS,CAAC,EAC/C,6BAA6B,CACnB,CAAC;AACf,CAAC;AAEM,KAAK,UAAU,SAAS,CAC7B,OAAoB;IAEpB,MAAM,WAAW,GAAG,MAAM,IAAA,wBAAc,EAAC,OAAO,CAAC,CAAC;IAClD,IAAI,CAAC,WAAW;QAAE,OAAO,IAAI,CAAC;IAE9B,OAAO;QACL,OAAO,EAAE,WAAW,CAAC,QAAQ;QAC7B,WAAW,EAAE,WAAW,CAAC,YAAY;QACrC,YAAY,EAAE,WAAW,CAAC,aAAa;KACxC,CAAC;AACJ,CAAC","sourcesContent":["import { retrieveTokens } from \"@/shared/lib/util.js\";\nimport { decodeJwt, type JWTPayload } from \"jose\";\nimport {\n tokenKeys,\n type AuthStorage,\n type OAuthTokens,\n type User,\n type EmptyObject,\n type UnknownObject,\n} from \"@/types.js\";\nimport { JWT_PAYLOAD_KNOWN_CLAIM_KEYS } from \"@/constants.js\";\n\n// Function to omit keys from an object\nconst omitKeys = <K extends keyof T, T extends Record<string, unknown>>(\n keys: K[],\n obj: T,\n): Omit<T, K> => {\n const result = { ...obj };\n keys.forEach((key) => {\n delete result[key];\n });\n return result;\n};\n\nconst parseJWTToType = <T extends UnknownObject = EmptyObject>(\n jwt: string,\n): JWTPayload & T => {\n const parseResult = decodeJwt(jwt);\n return parseResult as JWTPayload & T;\n};\n\nexport async function getUser<T extends UnknownObject = EmptyObject>(\n storage: AuthStorage,\n): Promise<User<T> | null> {\n const tokens = await retrieveTokens(storage);\n if (!tokens) return null;\n\n const parsedToken = parseJWTToType<T>(tokens.id_token);\n // it might be preferable to throw here\n if (!parsedToken.sub) return null;\n\n // set the user ID from the token sub\n const userWithAdditionalTokenFields = {\n ...(parsedToken as T),\n id: parsedToken.sub,\n };\n\n // Assumes all information is in the ID token\n // remove the token keys from the user object to stop it getting too large\n return omitKeys(\n [...JWT_PAYLOAD_KNOWN_CLAIM_KEYS, ...tokenKeys],\n userWithAdditionalTokenFields,\n ) as User<T>;\n}\n\nexport async function getTokens(\n storage: AuthStorage,\n): Promise<OAuthTokens | null> {\n const storageData = await retrieveTokens(storage);\n if (!storageData) return null;\n\n return {\n idToken: storageData.id_token,\n accessToken: storageData.access_token,\n refreshToken: storageData.refresh_token,\n };\n}\n"]}
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
import type { AuthStorage, SessionData, UnknownObject, User } from "../../types.js";
|
|
2
|
-
type SameSiteOption = "strict" | "lax" | "none";
|
|
3
|
-
export interface SessionStorage {
|
|
4
|
-
get(): SessionData;
|
|
5
|
-
getUser(): User<UnknownObject> | null;
|
|
6
|
-
set(data: Partial<SessionData>): void;
|
|
7
|
-
setUser(data: User<UnknownObject> | null): void;
|
|
8
|
-
clear(): void;
|
|
9
|
-
}
|
|
10
|
-
export type CookieStorageSettings = {
|
|
11
|
-
httpOnly: boolean;
|
|
12
|
-
secure: boolean;
|
|
13
|
-
sameSite: SameSiteOption;
|
|
14
|
-
expires: Date;
|
|
15
|
-
path: string;
|
|
16
|
-
};
|
|
17
|
-
export declare const DEFAULT_COOKIE_DURATION: number;
|
|
18
|
-
export declare abstract class CookieStorage implements AuthStorage {
|
|
19
|
-
protected settings: CookieStorageSettings;
|
|
20
|
-
protected constructor(settings?: Partial<CookieStorageSettings>);
|
|
21
|
-
abstract get(key: string): Promise<string | null>;
|
|
22
|
-
abstract set(key: string, value: string): Promise<void>;
|
|
23
|
-
abstract delete(key: string): Promise<void>;
|
|
24
|
-
}
|
|
25
|
-
export type AuthCookieStorageSettings = {
|
|
26
|
-
httpOnly: boolean;
|
|
27
|
-
secure: boolean;
|
|
28
|
-
sameSite: SameSiteOption;
|
|
29
|
-
expires: Date;
|
|
30
|
-
path: string;
|
|
31
|
-
timestamp: Date;
|
|
32
|
-
};
|
|
33
|
-
export {};
|
|
34
|
-
//# sourceMappingURL=storage.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"storage.d.ts","sourceRoot":"","sources":["../../../../src/shared/lib/storage.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,WAAW,EAAE,aAAa,EAAE,IAAI,EAAE,MAAM,YAAY,CAAC;AAEhF,KAAK,cAAc,GAAG,QAAQ,GAAG,KAAK,GAAG,MAAM,CAAC;AAEhD,MAAM,WAAW,cAAc;IAC7B,GAAG,IAAI,WAAW,CAAC;IACnB,OAAO,IAAI,IAAI,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC;IACtC,GAAG,CAAC,IAAI,EAAE,OAAO,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC;IACtC,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC,aAAa,CAAC,GAAG,IAAI,GAAG,IAAI,CAAC;IAChD,KAAK,IAAI,IAAI,CAAC;CACf;AAED,MAAM,MAAM,qBAAqB,GAAG;IAClC,QAAQ,EAAE,OAAO,CAAC;IAClB,MAAM,EAAE,OAAO,CAAC;IAChB,QAAQ,EAAE,cAAc,CAAC;IACzB,OAAO,EAAE,IAAI,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;CACd,CAAC;AAEF,eAAO,MAAM,uBAAuB,QAAU,CAAC;AAE/C,8BAAsB,aAAc,YAAW,WAAW;IACxD,SAAS,CAAC,QAAQ,EAAE,qBAAqB,CAAC;IAC1C,SAAS,aAAa,QAAQ,GAAE,OAAO,CAAC,qBAAqB,CAAM;IAanE,QAAQ,CAAC,GAAG,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;IACjD,QAAQ,CAAC,GAAG,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IACvD,QAAQ,CAAC,MAAM,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAC5C;AAED,MAAM,MAAM,yBAAyB,GAAG;IACtC,QAAQ,EAAE,OAAO,CAAC;IAClB,MAAM,EAAE,OAAO,CAAC;IAChB,QAAQ,EAAE,cAAc,CAAC;IACzB,OAAO,EAAE,IAAI,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,IAAI,CAAC;CACjB,CAAC"}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.CookieStorage = exports.DEFAULT_COOKIE_DURATION = void 0;
|
|
4
|
-
exports.DEFAULT_COOKIE_DURATION = 60 * 15; // 15 minutes
|
|
5
|
-
class CookieStorage {
|
|
6
|
-
settings;
|
|
7
|
-
constructor(settings = {}) {
|
|
8
|
-
this.settings = {
|
|
9
|
-
httpOnly: settings.httpOnly ?? true,
|
|
10
|
-
secure: settings.secure ?? true,
|
|
11
|
-
// the callback request comes the auth server
|
|
12
|
-
// 'lax' ensures the code_verifier cookie is sent with the request
|
|
13
|
-
sameSite: settings.sameSite ?? "lax",
|
|
14
|
-
expires: settings.expires ??
|
|
15
|
-
new Date(Date.now() + 1000 * exports.DEFAULT_COOKIE_DURATION),
|
|
16
|
-
path: settings.path ?? "/",
|
|
17
|
-
};
|
|
18
|
-
}
|
|
19
|
-
}
|
|
20
|
-
exports.CookieStorage = CookieStorage;
|
|
21
|
-
//# sourceMappingURL=storage.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"storage.js","sourceRoot":"","sources":["../../../../src/shared/lib/storage.ts"],"names":[],"mappings":";;;AAoBa,QAAA,uBAAuB,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC,aAAa;AAE7D,MAAsB,aAAa;IACvB,QAAQ,CAAwB;IAC1C,YAAsB,WAA2C,EAAE;QACjE,IAAI,CAAC,QAAQ,GAAG;YACd,QAAQ,EAAE,QAAQ,CAAC,QAAQ,IAAI,IAAI;YACnC,MAAM,EAAE,QAAQ,CAAC,MAAM,IAAI,IAAI;YAC/B,6CAA6C;YAC7C,kEAAkE;YAClE,QAAQ,EAAE,QAAQ,CAAC,QAAQ,IAAI,KAAK;YACpC,OAAO,EACL,QAAQ,CAAC,OAAO;gBAChB,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,GAAG,+BAAuB,CAAC;YACvD,IAAI,EAAE,QAAQ,CAAC,IAAI,IAAI,GAAG;SAC3B,CAAC;IACJ,CAAC;CAIF;AAlBD,sCAkBC","sourcesContent":["import type { AuthStorage, SessionData, UnknownObject, User } from \"@/types.js\";\n\ntype SameSiteOption = \"strict\" | \"lax\" | \"none\";\n\nexport interface SessionStorage {\n get(): SessionData;\n getUser(): User<UnknownObject> | null;\n set(data: Partial<SessionData>): void;\n setUser(data: User<UnknownObject> | null): void;\n clear(): void;\n}\n\nexport type CookieStorageSettings = {\n httpOnly: boolean;\n secure: boolean;\n sameSite: SameSiteOption;\n expires: Date;\n path: string;\n};\n\nexport const DEFAULT_COOKIE_DURATION = 60 * 15; // 15 minutes\n\nexport abstract class CookieStorage implements AuthStorage {\n protected settings: CookieStorageSettings;\n protected constructor(settings: Partial<CookieStorageSettings> = {}) {\n this.settings = {\n httpOnly: settings.httpOnly ?? true,\n secure: settings.secure ?? true,\n // the callback request comes the auth server\n // 'lax' ensures the code_verifier cookie is sent with the request\n sameSite: settings.sameSite ?? \"lax\",\n expires:\n settings.expires ??\n new Date(Date.now() + 1000 * DEFAULT_COOKIE_DURATION),\n path: settings.path ?? \"/\",\n };\n }\n abstract get(key: string): Promise<string | null>;\n abstract set(key: string, value: string): Promise<void>;\n abstract delete(key: string): Promise<void>;\n}\n\nexport type AuthCookieStorageSettings = {\n httpOnly: boolean;\n secure: boolean;\n sameSite: SameSiteOption;\n expires: Date;\n path: string;\n timestamp: Date;\n};\n"]}
|
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
import type { Endpoints } from "../../types.js";
|
|
2
|
-
export declare enum OAuthTokens {
|
|
3
|
-
ID_TOKEN = "id_token",
|
|
4
|
-
ACCESS_TOKEN = "access_token",
|
|
5
|
-
REFRESH_TOKEN = "refresh_token",
|
|
6
|
-
ACCESS_TOKEN_EXPIRES_AT = "access_token_expires_at"
|
|
7
|
-
}
|
|
8
|
-
export declare const AUTH_SERVER_SESSION = "_session";
|
|
9
|
-
export declare const AUTH_SERVER_LEGACY_SESSION = "_session.legacy";
|
|
10
|
-
export declare enum CodeVerifier {
|
|
11
|
-
COOKIE_NAME = "code_verifier",
|
|
12
|
-
APP_URL = "app_url"
|
|
13
|
-
}
|
|
14
|
-
export declare enum UserStorage {
|
|
15
|
-
USER = "user"
|
|
16
|
-
}
|
|
17
|
-
export interface CookieConfig {
|
|
18
|
-
secure?: boolean;
|
|
19
|
-
sameSite?: "strict" | "lax" | "none";
|
|
20
|
-
domain?: string;
|
|
21
|
-
path?: string;
|
|
22
|
-
maxAge?: number;
|
|
23
|
-
httpOnly?: boolean;
|
|
24
|
-
}
|
|
25
|
-
export type TokensCookieConfig = Record<OAuthTokens | CodeVerifier, CookieConfig>;
|
|
26
|
-
export type CivicAuthConfig = null | {
|
|
27
|
-
clientId: string;
|
|
28
|
-
redirectUrl: string;
|
|
29
|
-
logoutRedirectUrl: string;
|
|
30
|
-
oauthServer: string;
|
|
31
|
-
endpoints: Endpoints;
|
|
32
|
-
scopes: string[];
|
|
33
|
-
nonce?: string;
|
|
34
|
-
challengeUrl?: string;
|
|
35
|
-
refreshUrl?: string;
|
|
36
|
-
logoutUrl?: string;
|
|
37
|
-
};
|
|
38
|
-
//# sourceMappingURL=types.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/shared/lib/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AAE5C,oBAAY,WAAW;IACrB,QAAQ,aAAa;IACrB,YAAY,iBAAiB;IAC7B,aAAa,kBAAkB;IAC/B,uBAAuB,4BAA4B;CACpD;AAED,eAAO,MAAM,mBAAmB,aAAa,CAAC;AAC9C,eAAO,MAAM,0BAA0B,oBAAoB,CAAC;AAE5D,oBAAY,YAAY;IACtB,WAAW,kBAAkB;IAC7B,OAAO,YAAY;CACpB;AACD,oBAAY,WAAW;IACrB,IAAI,SAAS;CACd;AACD,MAAM,WAAW,YAAY;IAC3B,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,QAAQ,CAAC,EAAE,QAAQ,GAAG,KAAK,GAAG,MAAM,CAAC;IACrC,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,MAAM,MAAM,kBAAkB,GAAG,MAAM,CACrC,WAAW,GAAG,YAAY,EAC1B,YAAY,CACb,CAAC;AAEF,MAAM,MAAM,eAAe,GAAG,IAAI,GAAG;IACnC,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,EAAE,MAAM,CAAC;IACpB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,SAAS,CAAC;IACrB,MAAM,EAAE,MAAM,EAAE,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,CAAC"}
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.UserStorage = exports.CodeVerifier = exports.AUTH_SERVER_LEGACY_SESSION = exports.AUTH_SERVER_SESSION = exports.OAuthTokens = void 0;
|
|
4
|
-
var OAuthTokens;
|
|
5
|
-
(function (OAuthTokens) {
|
|
6
|
-
OAuthTokens["ID_TOKEN"] = "id_token";
|
|
7
|
-
OAuthTokens["ACCESS_TOKEN"] = "access_token";
|
|
8
|
-
OAuthTokens["REFRESH_TOKEN"] = "refresh_token";
|
|
9
|
-
OAuthTokens["ACCESS_TOKEN_EXPIRES_AT"] = "access_token_expires_at";
|
|
10
|
-
})(OAuthTokens || (exports.OAuthTokens = OAuthTokens = {}));
|
|
11
|
-
exports.AUTH_SERVER_SESSION = "_session";
|
|
12
|
-
exports.AUTH_SERVER_LEGACY_SESSION = "_session.legacy";
|
|
13
|
-
var CodeVerifier;
|
|
14
|
-
(function (CodeVerifier) {
|
|
15
|
-
CodeVerifier["COOKIE_NAME"] = "code_verifier";
|
|
16
|
-
CodeVerifier["APP_URL"] = "app_url";
|
|
17
|
-
})(CodeVerifier || (exports.CodeVerifier = CodeVerifier = {}));
|
|
18
|
-
var UserStorage;
|
|
19
|
-
(function (UserStorage) {
|
|
20
|
-
UserStorage["USER"] = "user";
|
|
21
|
-
})(UserStorage || (exports.UserStorage = UserStorage = {}));
|
|
22
|
-
//# sourceMappingURL=types.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/shared/lib/types.ts"],"names":[],"mappings":";;;AAEA,IAAY,WAKX;AALD,WAAY,WAAW;IACrB,oCAAqB,CAAA;IACrB,4CAA6B,CAAA;IAC7B,8CAA+B,CAAA;IAC/B,kEAAmD,CAAA;AACrD,CAAC,EALW,WAAW,2BAAX,WAAW,QAKtB;AAEY,QAAA,mBAAmB,GAAG,UAAU,CAAC;AACjC,QAAA,0BAA0B,GAAG,iBAAiB,CAAC;AAE5D,IAAY,YAGX;AAHD,WAAY,YAAY;IACtB,6CAA6B,CAAA;IAC7B,mCAAmB,CAAA;AACrB,CAAC,EAHW,YAAY,4BAAZ,YAAY,QAGvB;AACD,IAAY,WAEX;AAFD,WAAY,WAAW;IACrB,4BAAa,CAAA;AACf,CAAC,EAFW,WAAW,2BAAX,WAAW,QAEtB","sourcesContent":["import type { Endpoints } from \"@/types.js\";\n\nexport enum OAuthTokens {\n ID_TOKEN = \"id_token\",\n ACCESS_TOKEN = \"access_token\",\n REFRESH_TOKEN = \"refresh_token\",\n ACCESS_TOKEN_EXPIRES_AT = \"access_token_expires_at\",\n}\n\nexport const AUTH_SERVER_SESSION = \"_session\";\nexport const AUTH_SERVER_LEGACY_SESSION = \"_session.legacy\";\n\nexport enum CodeVerifier {\n COOKIE_NAME = \"code_verifier\",\n APP_URL = \"app_url\",\n}\nexport enum UserStorage {\n USER = \"user\",\n}\nexport interface CookieConfig {\n secure?: boolean;\n sameSite?: \"strict\" | \"lax\" | \"none\";\n domain?: string;\n path?: string;\n maxAge?: number;\n httpOnly?: boolean;\n}\n\nexport type TokensCookieConfig = Record<\n OAuthTokens | CodeVerifier,\n CookieConfig\n>;\n\nexport type CivicAuthConfig = null | {\n clientId: string;\n redirectUrl: string;\n logoutRedirectUrl: string;\n oauthServer: string;\n endpoints: Endpoints;\n scopes: string[];\n nonce?: string;\n challengeUrl?: string;\n refreshUrl?: string;\n logoutUrl?: string;\n};\n"]}
|
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
import type { AuthStorage, Endpoints, OIDCTokenResponseBody, ParsedTokens } from "../../types.js";
|
|
2
|
-
import { OAuth2Client } from "oslo/oauth2";
|
|
3
|
-
import type { PKCEConsumer, PKCEProducer } from "../../services/types.js";
|
|
4
|
-
/**
|
|
5
|
-
* Given a PKCE code verifier, derive the code challenge using SHA
|
|
6
|
-
*/
|
|
7
|
-
export declare function deriveCodeChallenge(codeVerifier: string, method?: "Plain" | "S256"): Promise<string>;
|
|
8
|
-
export declare function getEndpointsWithOverrides(oauthServer: string, endpointOverrides?: Partial<Endpoints>): Promise<Endpoints>;
|
|
9
|
-
export declare function generateOauthLoginUrl(config: {
|
|
10
|
-
clientId: string;
|
|
11
|
-
scopes: string[];
|
|
12
|
-
state: string;
|
|
13
|
-
redirectUrl: string;
|
|
14
|
-
oauthServer: string;
|
|
15
|
-
nonce?: string;
|
|
16
|
-
endpointOverrides?: Partial<Endpoints>;
|
|
17
|
-
pkceConsumer: PKCEConsumer;
|
|
18
|
-
}): Promise<URL>;
|
|
19
|
-
export declare function generateOauthLogoutUrl(config: {
|
|
20
|
-
clientId: string;
|
|
21
|
-
redirectUrl: string;
|
|
22
|
-
idToken: string;
|
|
23
|
-
state: string;
|
|
24
|
-
oauthServer: string;
|
|
25
|
-
endpointOverrides?: Partial<Endpoints>;
|
|
26
|
-
}): Promise<URL>;
|
|
27
|
-
export declare function buildOauth2Client(clientId: string, redirectUri: string, endpoints: Endpoints): OAuth2Client;
|
|
28
|
-
export declare function exchangeTokens(code: string, state: string, pkceProducer: PKCEProducer, oauth2Client: OAuth2Client, oauthServer: string, endpoints: Endpoints): Promise<OIDCTokenResponseBody>;
|
|
29
|
-
export declare function setAccessTokenExpiresAt(storage: AuthStorage, tokens: OIDCTokenResponseBody): Promise<void>;
|
|
30
|
-
export declare function storeTokens(storage: AuthStorage, tokens: OIDCTokenResponseBody): Promise<void>;
|
|
31
|
-
export declare function clearTokens(storage: AuthStorage): Promise<void>;
|
|
32
|
-
export declare function clearAuthServerSession(storage: AuthStorage): Promise<void>;
|
|
33
|
-
export declare function clearUser(storage: AuthStorage): Promise<void>;
|
|
34
|
-
export declare function retrieveTokens(storage: AuthStorage): Promise<OIDCTokenResponseBody | null>;
|
|
35
|
-
export declare function retrieveAccessTokenExpiresAt(storage: AuthStorage): Promise<number>;
|
|
36
|
-
export declare function validateOauth2Tokens(tokens: OIDCTokenResponseBody, endpoints: Endpoints, oauth2Client: OAuth2Client, issuer: string): Promise<ParsedTokens>;
|
|
37
|
-
//# sourceMappingURL=util.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"util.d.ts","sourceRoot":"","sources":["../../../../src/shared/lib/util.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EACV,WAAW,EACX,SAAS,EACT,qBAAqB,EACrB,YAAY,EACb,MAAM,YAAY,CAAC;AAMpB,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAI3C,OAAO,KAAK,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAItE;;GAEG;AACH,wBAAsB,mBAAmB,CACvC,YAAY,EAAE,MAAM,EACpB,MAAM,GAAE,OAAO,GAAG,MAAe,GAChC,OAAO,CAAC,MAAM,CAAC,CAajB;AAED,wBAAsB,yBAAyB,CAC7C,WAAW,EAAE,MAAM,EACnB,iBAAiB,GAAE,OAAO,CAAC,SAAS,CAAM,GACzC,OAAO,CAAC,SAAS,CAAC,CAMpB;AAED,wBAAsB,qBAAqB,CAAC,MAAM,EAAE;IAClD,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,EAAE,MAAM,EAAE,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,EAAE,MAAM,CAAC;IACpB,WAAW,EAAE,MAAM,CAAC;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,iBAAiB,CAAC,EAAE,OAAO,CAAC,SAAS,CAAC,CAAC;IAEvC,YAAY,EAAE,YAAY,CAAC;CAC5B,GAAG,OAAO,CAAC,GAAG,CAAC,CA2Bf;AAED,wBAAsB,sBAAsB,CAAC,MAAM,EAAE;IACnD,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,EAAE,MAAM,CAAC;IACpB,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,EAAE,MAAM,CAAC;IACpB,iBAAiB,CAAC,EAAE,OAAO,CAAC,SAAS,CAAC,CAAC;CACxC,GAAG,OAAO,CAAC,GAAG,CAAC,CAcf;AAED,wBAAgB,iBAAiB,CAC/B,QAAQ,EAAE,MAAM,EAChB,WAAW,EAAE,MAAM,EACnB,SAAS,EAAE,SAAS,GACnB,YAAY,CAId;AAED,wBAAsB,cAAc,CAClC,IAAI,EAAE,MAAM,EACZ,KAAK,EAAE,MAAM,EACb,YAAY,EAAE,YAAY,EAC1B,YAAY,EAAE,YAAY,EAC1B,WAAW,EAAE,MAAM,EACnB,SAAS,EAAE,SAAS,kCAoBrB;AAED,wBAAsB,uBAAuB,CAC3C,OAAO,EAAE,WAAW,EACpB,MAAM,EAAE,qBAAqB,iBAkB9B;AAED,wBAAsB,WAAW,CAC/B,OAAO,EAAE,WAAW,EACpB,MAAM,EAAE,qBAAqB,iBAS9B;AAED,wBAAsB,WAAW,CAAC,OAAO,EAAE,WAAW,iBAKrD;AAED,wBAAsB,sBAAsB,CAAC,OAAO,EAAE,WAAW,iBAGhE;AAED,wBAAsB,SAAS,CAAC,OAAO,EAAE,WAAW,iBAGnD;AAED,wBAAsB,cAAc,CAClC,OAAO,EAAE,WAAW,GACnB,OAAO,CAAC,qBAAqB,GAAG,IAAI,CAAC,CAmBvC;AAED,wBAAsB,4BAA4B,CAChD,OAAO,EAAE,WAAW,GACnB,OAAO,CAAC,MAAM,CAAC,CAEjB;AAED,wBAAsB,oBAAoB,CACxC,MAAM,EAAE,qBAAqB,EAC7B,SAAS,EAAE,SAAS,EACpB,YAAY,EAAE,YAAY,EAC1B,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,YAAY,CAAC,CA2BvB"}
|
|
@@ -1,204 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
-
}) : function(o, v) {
|
|
16
|
-
o["default"] = v;
|
|
17
|
-
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
-
var ownKeys = function(o) {
|
|
20
|
-
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
-
var ar = [];
|
|
22
|
-
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
-
return ar;
|
|
24
|
-
};
|
|
25
|
-
return ownKeys(o);
|
|
26
|
-
};
|
|
27
|
-
return function (mod) {
|
|
28
|
-
if (mod && mod.__esModule) return mod;
|
|
29
|
-
var result = {};
|
|
30
|
-
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
-
__setModuleDefault(result, mod);
|
|
32
|
-
return result;
|
|
33
|
-
};
|
|
34
|
-
})();
|
|
35
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
-
exports.deriveCodeChallenge = deriveCodeChallenge;
|
|
37
|
-
exports.getEndpointsWithOverrides = getEndpointsWithOverrides;
|
|
38
|
-
exports.generateOauthLoginUrl = generateOauthLoginUrl;
|
|
39
|
-
exports.generateOauthLogoutUrl = generateOauthLogoutUrl;
|
|
40
|
-
exports.buildOauth2Client = buildOauth2Client;
|
|
41
|
-
exports.exchangeTokens = exchangeTokens;
|
|
42
|
-
exports.setAccessTokenExpiresAt = setAccessTokenExpiresAt;
|
|
43
|
-
exports.storeTokens = storeTokens;
|
|
44
|
-
exports.clearTokens = clearTokens;
|
|
45
|
-
exports.clearAuthServerSession = clearAuthServerSession;
|
|
46
|
-
exports.clearUser = clearUser;
|
|
47
|
-
exports.retrieveTokens = retrieveTokens;
|
|
48
|
-
exports.retrieveAccessTokenExpiresAt = retrieveAccessTokenExpiresAt;
|
|
49
|
-
exports.validateOauth2Tokens = validateOauth2Tokens;
|
|
50
|
-
const types_js_1 = require("./types.js");
|
|
51
|
-
const oauth2_1 = require("oslo/oauth2");
|
|
52
|
-
const oauth_js_1 = require("../../lib/oauth.js");
|
|
53
|
-
const jose = __importStar(require("jose"));
|
|
54
|
-
const utils_js_1 = require("../../utils.js");
|
|
55
|
-
const UserSession_js_1 = require("../../shared/lib/UserSession.js");
|
|
56
|
-
const jose_1 = require("jose");
|
|
57
|
-
/**
|
|
58
|
-
* Given a PKCE code verifier, derive the code challenge using SHA
|
|
59
|
-
*/
|
|
60
|
-
async function deriveCodeChallenge(codeVerifier, method = "S256") {
|
|
61
|
-
if (method === "Plain") {
|
|
62
|
-
console.warn("Using insecure plain code challenge method");
|
|
63
|
-
return codeVerifier;
|
|
64
|
-
}
|
|
65
|
-
const encoder = new TextEncoder();
|
|
66
|
-
const data = encoder.encode(codeVerifier);
|
|
67
|
-
const digest = await crypto.subtle.digest("SHA-256", data);
|
|
68
|
-
return btoa(String.fromCharCode(...new Uint8Array(digest)))
|
|
69
|
-
.replace(/\+/g, "-")
|
|
70
|
-
.replace(/\//g, "_")
|
|
71
|
-
.replace(/=+$/, "");
|
|
72
|
-
}
|
|
73
|
-
async function getEndpointsWithOverrides(oauthServer, endpointOverrides = {}) {
|
|
74
|
-
const endpoints = await (0, oauth_js_1.getOauthEndpoints)(oauthServer);
|
|
75
|
-
return {
|
|
76
|
-
...endpoints,
|
|
77
|
-
...endpointOverrides,
|
|
78
|
-
};
|
|
79
|
-
}
|
|
80
|
-
async function generateOauthLoginUrl(config) {
|
|
81
|
-
const endpoints = await getEndpointsWithOverrides(config.oauthServer, config.endpointOverrides);
|
|
82
|
-
const oauth2Client = buildOauth2Client(config.clientId, config.redirectUrl, endpoints);
|
|
83
|
-
const challenge = await config.pkceConsumer.getCodeChallenge();
|
|
84
|
-
const oAuthUrl = await oauth2Client.createAuthorizationURL({
|
|
85
|
-
state: config.state,
|
|
86
|
-
scopes: config.scopes,
|
|
87
|
-
});
|
|
88
|
-
// The OAuth2 client supports PKCE, but does not allow passing in a code challenge from some other source
|
|
89
|
-
// It only allows passing in a code verifier which it then hashes itself.
|
|
90
|
-
oAuthUrl.searchParams.append("code_challenge", challenge);
|
|
91
|
-
oAuthUrl.searchParams.append("code_challenge_method", "S256");
|
|
92
|
-
if (config.nonce) {
|
|
93
|
-
// nonce isn't supported by oslo, so we add it manually
|
|
94
|
-
oAuthUrl.searchParams.append("nonce", config.nonce);
|
|
95
|
-
}
|
|
96
|
-
// Required by the auth server for offline_access scope
|
|
97
|
-
oAuthUrl.searchParams.append("prompt", "consent");
|
|
98
|
-
return oAuthUrl;
|
|
99
|
-
}
|
|
100
|
-
async function generateOauthLogoutUrl(config) {
|
|
101
|
-
const endpoints = await getEndpointsWithOverrides(config.oauthServer, config.endpointOverrides);
|
|
102
|
-
const endSessionUrl = new URL(endpoints.endsession);
|
|
103
|
-
endSessionUrl.searchParams.append("client_id", config.clientId);
|
|
104
|
-
endSessionUrl.searchParams.append("id_token_hint", config.idToken);
|
|
105
|
-
endSessionUrl.searchParams.append("state", config.state);
|
|
106
|
-
endSessionUrl.searchParams.append("post_logout_redirect_uri", config.redirectUrl);
|
|
107
|
-
return endSessionUrl;
|
|
108
|
-
}
|
|
109
|
-
function buildOauth2Client(clientId, redirectUri, endpoints) {
|
|
110
|
-
return new oauth2_1.OAuth2Client(clientId, endpoints.auth, endpoints.token, {
|
|
111
|
-
redirectURI: redirectUri,
|
|
112
|
-
});
|
|
113
|
-
}
|
|
114
|
-
async function exchangeTokens(code, state, pkceProducer, oauth2Client, oauthServer, endpoints) {
|
|
115
|
-
const codeVerifier = await pkceProducer.getCodeVerifier();
|
|
116
|
-
if (!codeVerifier)
|
|
117
|
-
throw new Error("Code verifier not found in state");
|
|
118
|
-
const tokens = await oauth2Client.validateAuthorizationCode(code, {
|
|
119
|
-
codeVerifier,
|
|
120
|
-
});
|
|
121
|
-
// Validate relevant tokens
|
|
122
|
-
try {
|
|
123
|
-
await validateOauth2Tokens(tokens, endpoints, oauth2Client, oauthServer);
|
|
124
|
-
}
|
|
125
|
-
catch (error) {
|
|
126
|
-
console.error("tokenExchange error", { error, tokens });
|
|
127
|
-
throw new Error(`OIDC tokens validation failed: ${error.message}`);
|
|
128
|
-
}
|
|
129
|
-
return tokens;
|
|
130
|
-
}
|
|
131
|
-
async function setAccessTokenExpiresAt(storage, tokens) {
|
|
132
|
-
// try to extract absolute expiry time from access token but fallback to calculation if not possible
|
|
133
|
-
const parsedAccessToken = (0, jose_1.decodeJwt)(tokens.access_token);
|
|
134
|
-
if (parsedAccessToken?.exp) {
|
|
135
|
-
await storage.set(types_js_1.OAuthTokens.ACCESS_TOKEN_EXPIRES_AT, parsedAccessToken.exp.toString());
|
|
136
|
-
}
|
|
137
|
-
else if (tokens.expires_in) {
|
|
138
|
-
const now = Math.floor(new Date().getTime() / 1000);
|
|
139
|
-
await storage.set(types_js_1.OAuthTokens.ACCESS_TOKEN_EXPIRES_AT, (now + tokens.expires_in).toString());
|
|
140
|
-
}
|
|
141
|
-
else {
|
|
142
|
-
throw new Error("Cannot determine access token expiry!");
|
|
143
|
-
}
|
|
144
|
-
}
|
|
145
|
-
async function storeTokens(storage, tokens) {
|
|
146
|
-
// store tokens in storage ( TODO we should probably store them against the state to allow multiple logins )
|
|
147
|
-
await storage.set(types_js_1.OAuthTokens.ID_TOKEN, tokens.id_token);
|
|
148
|
-
await storage.set(types_js_1.OAuthTokens.ACCESS_TOKEN, tokens.access_token);
|
|
149
|
-
if (tokens.refresh_token) {
|
|
150
|
-
await storage.set(types_js_1.OAuthTokens.REFRESH_TOKEN, tokens.refresh_token);
|
|
151
|
-
}
|
|
152
|
-
await setAccessTokenExpiresAt(storage, tokens);
|
|
153
|
-
}
|
|
154
|
-
async function clearTokens(storage) {
|
|
155
|
-
const clearOAuthPromises = Object.values(types_js_1.OAuthTokens).map(async (key) => {
|
|
156
|
-
await storage.delete(key);
|
|
157
|
-
});
|
|
158
|
-
await Promise.all([...clearOAuthPromises]);
|
|
159
|
-
}
|
|
160
|
-
async function clearAuthServerSession(storage) {
|
|
161
|
-
await storage.delete(types_js_1.AUTH_SERVER_SESSION);
|
|
162
|
-
await storage.delete(types_js_1.AUTH_SERVER_LEGACY_SESSION);
|
|
163
|
-
}
|
|
164
|
-
async function clearUser(storage) {
|
|
165
|
-
const userSession = new UserSession_js_1.GenericUserSession(storage);
|
|
166
|
-
await userSession.clear();
|
|
167
|
-
}
|
|
168
|
-
async function retrieveTokens(storage) {
|
|
169
|
-
const idToken = await storage.get(types_js_1.OAuthTokens.ID_TOKEN);
|
|
170
|
-
const accessToken = await storage.get(types_js_1.OAuthTokens.ACCESS_TOKEN);
|
|
171
|
-
const refreshToken = await storage.get(types_js_1.OAuthTokens.REFRESH_TOKEN);
|
|
172
|
-
const accessTokenExpiresAt = await storage.get(types_js_1.OAuthTokens.ACCESS_TOKEN_EXPIRES_AT);
|
|
173
|
-
if (!idToken || !accessToken)
|
|
174
|
-
return null;
|
|
175
|
-
return {
|
|
176
|
-
id_token: idToken,
|
|
177
|
-
access_token: accessToken,
|
|
178
|
-
refresh_token: refreshToken ?? undefined,
|
|
179
|
-
access_token_expires_at: accessTokenExpiresAt !== null
|
|
180
|
-
? parseInt(accessTokenExpiresAt, 10)
|
|
181
|
-
: undefined, // Convert string to number
|
|
182
|
-
};
|
|
183
|
-
}
|
|
184
|
-
async function retrieveAccessTokenExpiresAt(storage) {
|
|
185
|
-
return Number(await storage.get(types_js_1.OAuthTokens.ACCESS_TOKEN_EXPIRES_AT));
|
|
186
|
-
}
|
|
187
|
-
async function validateOauth2Tokens(tokens, endpoints, oauth2Client, issuer) {
|
|
188
|
-
const JWKS = jose.createRemoteJWKSet(new URL(endpoints.jwks));
|
|
189
|
-
// validate the ID token
|
|
190
|
-
const idTokenResponse = await jose.jwtVerify(tokens.id_token, JWKS, {
|
|
191
|
-
issuer: (0, oauth_js_1.getIssuerVariations)(issuer),
|
|
192
|
-
audience: oauth2Client.clientId,
|
|
193
|
-
});
|
|
194
|
-
// validate the access token
|
|
195
|
-
const accessTokenResponse = await jose.jwtVerify(tokens.access_token, JWKS, {
|
|
196
|
-
issuer: (0, oauth_js_1.getIssuerVariations)(issuer),
|
|
197
|
-
});
|
|
198
|
-
return (0, utils_js_1.withoutUndefined)({
|
|
199
|
-
id_token: idTokenResponse.payload,
|
|
200
|
-
access_token: accessTokenResponse.payload,
|
|
201
|
-
refresh_token: tokens.refresh_token,
|
|
202
|
-
});
|
|
203
|
-
}
|
|
204
|
-
//# sourceMappingURL=util.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"util.js","sourceRoot":"","sources":["../../../../src/shared/lib/util.ts"],"names":[],"mappings":"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","sourcesContent":["// Utility functions shared by auth server and client integrations\n// Typically these functions should be used inside AuthenticationInitiator and AuthenticationResolver implementations\nimport type {\n AuthStorage,\n Endpoints,\n OIDCTokenResponseBody,\n ParsedTokens,\n} from \"@/types.js\";\nimport {\n AUTH_SERVER_LEGACY_SESSION,\n AUTH_SERVER_SESSION,\n OAuthTokens,\n} from \"./types.js\";\nimport { OAuth2Client } from \"oslo/oauth2\";\nimport { getIssuerVariations, getOauthEndpoints } from \"@/lib/oauth.js\";\nimport * as jose from \"jose\";\nimport { withoutUndefined } from \"@/utils.js\";\nimport type { PKCEConsumer, PKCEProducer } from \"@/services/types.js\";\nimport { GenericUserSession } from \"@/shared/lib/UserSession.js\";\nimport { decodeJwt, type JWTPayload } from \"jose\";\n\n/**\n * Given a PKCE code verifier, derive the code challenge using SHA\n */\nexport async function deriveCodeChallenge(\n codeVerifier: string,\n method: \"Plain\" | \"S256\" = \"S256\",\n): Promise<string> {\n if (method === \"Plain\") {\n console.warn(\"Using insecure plain code challenge method\");\n return codeVerifier;\n }\n\n const encoder = new TextEncoder();\n const data = encoder.encode(codeVerifier);\n const digest = await crypto.subtle.digest(\"SHA-256\", data);\n return btoa(String.fromCharCode(...new Uint8Array(digest)))\n .replace(/\\+/g, \"-\")\n .replace(/\\//g, \"_\")\n .replace(/=+$/, \"\");\n}\n\nexport async function getEndpointsWithOverrides(\n oauthServer: string,\n endpointOverrides: Partial<Endpoints> = {},\n): Promise<Endpoints> {\n const endpoints = await getOauthEndpoints(oauthServer);\n return {\n ...endpoints,\n ...endpointOverrides,\n };\n}\n\nexport async function generateOauthLoginUrl(config: {\n clientId: string;\n scopes: string[];\n state: string;\n redirectUrl: string;\n oauthServer: string;\n nonce?: string;\n endpointOverrides?: Partial<Endpoints>;\n // used to get the PKCE challenge\n pkceConsumer: PKCEConsumer;\n}): Promise<URL> {\n const endpoints = await getEndpointsWithOverrides(\n config.oauthServer,\n config.endpointOverrides,\n );\n const oauth2Client = buildOauth2Client(\n config.clientId,\n config.redirectUrl,\n endpoints,\n );\n const challenge = await config.pkceConsumer.getCodeChallenge();\n const oAuthUrl = await oauth2Client.createAuthorizationURL({\n state: config.state,\n scopes: config.scopes,\n });\n // The OAuth2 client supports PKCE, but does not allow passing in a code challenge from some other source\n // It only allows passing in a code verifier which it then hashes itself.\n oAuthUrl.searchParams.append(\"code_challenge\", challenge);\n oAuthUrl.searchParams.append(\"code_challenge_method\", \"S256\");\n if (config.nonce) {\n // nonce isn't supported by oslo, so we add it manually\n oAuthUrl.searchParams.append(\"nonce\", config.nonce);\n }\n // Required by the auth server for offline_access scope\n oAuthUrl.searchParams.append(\"prompt\", \"consent\");\n\n return oAuthUrl;\n}\n\nexport async function generateOauthLogoutUrl(config: {\n clientId: string;\n redirectUrl: string;\n idToken: string;\n state: string;\n oauthServer: string;\n endpointOverrides?: Partial<Endpoints>;\n}): Promise<URL> {\n const endpoints = await getEndpointsWithOverrides(\n config.oauthServer,\n config.endpointOverrides,\n );\n const endSessionUrl = new URL(endpoints.endsession);\n endSessionUrl.searchParams.append(\"client_id\", config.clientId);\n endSessionUrl.searchParams.append(\"id_token_hint\", config.idToken);\n endSessionUrl.searchParams.append(\"state\", config.state);\n endSessionUrl.searchParams.append(\n \"post_logout_redirect_uri\",\n config.redirectUrl,\n );\n return endSessionUrl;\n}\n\nexport function buildOauth2Client(\n clientId: string,\n redirectUri: string,\n endpoints: Endpoints,\n): OAuth2Client {\n return new OAuth2Client(clientId, endpoints.auth, endpoints.token, {\n redirectURI: redirectUri,\n });\n}\n\nexport async function exchangeTokens(\n code: string,\n state: string,\n pkceProducer: PKCEProducer,\n oauth2Client: OAuth2Client,\n oauthServer: string,\n endpoints: Endpoints,\n) {\n const codeVerifier = await pkceProducer.getCodeVerifier();\n if (!codeVerifier) throw new Error(\"Code verifier not found in state\");\n\n const tokens =\n await oauth2Client.validateAuthorizationCode<OIDCTokenResponseBody>(code, {\n codeVerifier,\n });\n\n // Validate relevant tokens\n try {\n await validateOauth2Tokens(tokens, endpoints, oauth2Client, oauthServer);\n } catch (error) {\n console.error(\"tokenExchange error\", { error, tokens });\n throw new Error(\n `OIDC tokens validation failed: ${(error as Error).message}`,\n );\n }\n return tokens;\n}\n\nexport async function setAccessTokenExpiresAt(\n storage: AuthStorage,\n tokens: OIDCTokenResponseBody,\n) {\n // try to extract absolute expiry time from access token but fallback to calculation if not possible\n const parsedAccessToken = decodeJwt(tokens.access_token);\n if (parsedAccessToken?.exp) {\n await storage.set(\n OAuthTokens.ACCESS_TOKEN_EXPIRES_AT,\n parsedAccessToken.exp.toString(),\n );\n } else if (tokens.expires_in) {\n const now = Math.floor(new Date().getTime() / 1000);\n await storage.set(\n OAuthTokens.ACCESS_TOKEN_EXPIRES_AT,\n (now + tokens.expires_in).toString(),\n );\n } else {\n throw new Error(\"Cannot determine access token expiry!\");\n }\n}\n\nexport async function storeTokens(\n storage: AuthStorage,\n tokens: OIDCTokenResponseBody,\n) {\n // store tokens in storage ( TODO we should probably store them against the state to allow multiple logins )\n await storage.set(OAuthTokens.ID_TOKEN, tokens.id_token);\n await storage.set(OAuthTokens.ACCESS_TOKEN, tokens.access_token);\n if (tokens.refresh_token) {\n await storage.set(OAuthTokens.REFRESH_TOKEN, tokens.refresh_token);\n }\n await setAccessTokenExpiresAt(storage, tokens);\n}\n\nexport async function clearTokens(storage: AuthStorage) {\n const clearOAuthPromises = Object.values(OAuthTokens).map(async (key) => {\n await storage.delete(key);\n });\n await Promise.all([...clearOAuthPromises]);\n}\n\nexport async function clearAuthServerSession(storage: AuthStorage) {\n await storage.delete(AUTH_SERVER_SESSION);\n await storage.delete(AUTH_SERVER_LEGACY_SESSION);\n}\n\nexport async function clearUser(storage: AuthStorage) {\n const userSession = new GenericUserSession(storage);\n await userSession.clear();\n}\n\nexport async function retrieveTokens(\n storage: AuthStorage,\n): Promise<OIDCTokenResponseBody | null> {\n const idToken = await storage.get(OAuthTokens.ID_TOKEN);\n const accessToken = await storage.get(OAuthTokens.ACCESS_TOKEN);\n const refreshToken = await storage.get(OAuthTokens.REFRESH_TOKEN);\n const accessTokenExpiresAt = await storage.get(\n OAuthTokens.ACCESS_TOKEN_EXPIRES_AT,\n );\n\n if (!idToken || !accessToken) return null;\n\n return {\n id_token: idToken,\n access_token: accessToken,\n refresh_token: refreshToken ?? undefined,\n access_token_expires_at:\n accessTokenExpiresAt !== null\n ? parseInt(accessTokenExpiresAt, 10)\n : undefined, // Convert string to number\n };\n}\n\nexport async function retrieveAccessTokenExpiresAt(\n storage: AuthStorage,\n): Promise<number> {\n return Number(await storage.get(OAuthTokens.ACCESS_TOKEN_EXPIRES_AT));\n}\n\nexport async function validateOauth2Tokens(\n tokens: OIDCTokenResponseBody,\n endpoints: Endpoints,\n oauth2Client: OAuth2Client,\n issuer: string,\n): Promise<ParsedTokens> {\n const JWKS = jose.createRemoteJWKSet(new URL(endpoints.jwks));\n\n // validate the ID token\n const idTokenResponse = await jose.jwtVerify<JWTPayload>(\n tokens.id_token,\n JWKS,\n {\n issuer: getIssuerVariations(issuer),\n audience: oauth2Client.clientId,\n },\n );\n\n // validate the access token\n const accessTokenResponse = await jose.jwtVerify<JWTPayload>(\n tokens.access_token,\n JWKS,\n {\n issuer: getIssuerVariations(issuer),\n },\n );\n\n return withoutUndefined({\n id_token: idTokenResponse.payload,\n access_token: accessTokenResponse.payload,\n refresh_token: tokens.refresh_token,\n });\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"AuthContext.d.ts","sourceRoot":"","sources":["../../../../src/shared/providers/AuthContext.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAE1D,MAAM,MAAM,eAAe,GAAG;IAC5B,MAAM,EAAE,CAAC,WAAW,CAAC,EAAE,WAAW,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IACrD,eAAe,EAAE,OAAO,CAAC;IACzB,SAAS,EAAE,OAAO,CAAC;IACnB,KAAK,EAAE,KAAK,GAAG,IAAI,CAAC;IACpB,OAAO,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IAC7B,UAAU,EAAE,UAAU,CAAC;IACvB,WAAW,EAAE,WAAW,CAAC;CAC1B,CAAC;AACF,eAAO,MAAM,WAAW,iDAA8C,CAAC"}
|