@civic/auth 0.3.5 → 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/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/{cjs/constants.d.ts → constants.d.ts} +2 -1
- package/dist/constants.d.ts.map +1 -0
- package/dist/{esm/constants.js → constants.js} +2 -1
- 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.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.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/{esm/nextjs → nextjs}/routeHandler.js +3 -3
- 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/{esm/reactjs → reactjs}/components/UserButton.js +0 -1
- 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/{esm/server → server}/ServerAuthenticationResolver.js +2 -2
- 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.map +1 -0
- package/dist/{esm/services → services}/AuthenticationService.js +7 -9
- 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.map +1 -0
- package/dist/shared/components/CivicAuthIframe.d.ts.map +1 -0
- package/dist/shared/components/CivicAuthIframe.js.map +1 -0
- package/dist/shared/components/CivicAuthIframeContainer.d.ts.map +1 -0
- package/dist/{esm/shared → shared}/components/CivicAuthIframeContainer.js +0 -2
- 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.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.map +1 -0
- package/dist/{esm/shared → shared}/components/SVGLoading.js +4 -4
- 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/{esm/shared → shared}/hooks/useSignIn.js +3 -2
- 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/{cjs/shared → shared}/lib/AuthenticationRefresherImpl.d.ts +3 -2
- package/dist/shared/lib/AuthenticationRefresherImpl.d.ts.map +1 -0
- package/dist/{esm/shared → shared}/lib/AuthenticationRefresherImpl.js +6 -1
- package/dist/shared/lib/AuthenticationRefresherImpl.js.map +1 -0
- package/dist/{esm/shared → shared}/lib/BrowserCookieStorage.d.ts +2 -1
- package/dist/shared/lib/BrowserCookieStorage.d.ts.map +1 -0
- package/dist/{esm/shared → shared}/lib/BrowserCookieStorage.js +24 -20
- 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/{esm/shared → shared}/lib/storage.d.ts +2 -1
- package/dist/shared/lib/storage.d.ts.map +1 -0
- package/dist/shared/lib/storage.js.map +1 -0
- package/dist/{esm/shared → shared}/lib/types.d.ts +1 -0
- package/dist/shared/lib/types.d.ts.map +1 -0
- package/dist/shared/lib/types.js.map +1 -0
- package/dist/{cjs/shared → shared}/lib/util.d.ts +4 -1
- package/dist/shared/lib/util.d.ts.map +1 -0
- package/dist/{esm/shared → shared}/lib/util.js +39 -7
- 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.map +1 -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.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 +20 -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.map +0 -1
- package/dist/cjs/constants.js +0 -42
- 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 -16
- 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 -110
- 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/LoadingSpinner.d.ts +0 -7
- package/dist/cjs/reactjs/components/LoadingSpinner.d.ts.map +0 -1
- package/dist/cjs/reactjs/components/LoadingSpinner.js +0 -33
- package/dist/cjs/reactjs/components/LoadingSpinner.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.map +0 -1
- package/dist/cjs/services/AuthenticationService.js +0 -374
- 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 -32
- 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 -66
- 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 -160
- 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 -21
- 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.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 -170
- 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.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.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.map +0 -1
- package/dist/cjs/shared/providers/IframeProvider.js +0 -63
- 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.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 -14
- package/dist/esm/constants.d.ts.map +0 -1
- 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.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.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.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.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.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 -93
- package/dist/esm/services/AuthenticationService.d.ts.map +0 -1
- 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.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.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.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.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 -4
- package/dist/esm/shared/components/SVGLoading.d.ts.map +0 -1
- 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.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.map +0 -1
- package/dist/esm/shared/lib/BrowserCookieStorage.d.ts.map +0 -1
- 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.map +0 -1
- package/dist/esm/shared/lib/storage.js.map +0 -1
- 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.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 -25
- package/dist/esm/shared/providers/IframeProvider.d.ts.map +0 -1
- 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 -163
- 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/{esm/lib → lib}/postMessage.js +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/{esm/nextjs → nextjs}/middleware.js +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}/AuthenticationService.d.ts +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/{esm/shared → shared}/components/BlockDisplay.js +0 -0
- /package/dist/{cjs/shared → shared}/components/CivicAuthIframe.d.ts +0 -0
- /package/dist/{esm/shared → shared}/components/CivicAuthIframe.js +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/{esm/shared → shared}/components/CivicAuthLogoutIframeContainer.js +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}/components/SVGLoading.d.ts +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/IframeProvider.d.ts +0 -0
- /package/dist/{esm/shared → shared}/providers/IframeProvider.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/{cjs/types.d.ts → types.d.ts} +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
package/dist/cjs/server/index.js
DELETED
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.clearTokens = exports.buildLogoutRedirectUrl = exports.refreshTokens = exports.getTokens = exports.getUser = exports.buildLoginUrl = exports.isLoggedIn = exports.resolveOAuthAccessCode = exports.CookieStorage = void 0;
|
|
4
|
-
const index_js_1 = require("../shared/index.js");
|
|
5
|
-
(0, index_js_1.printVersion)();
|
|
6
|
-
var storage_js_1 = require("../shared/lib/storage.js");
|
|
7
|
-
Object.defineProperty(exports, "CookieStorage", { enumerable: true, get: function () { return storage_js_1.CookieStorage; } });
|
|
8
|
-
var login_js_1 = require("../server/login.js");
|
|
9
|
-
Object.defineProperty(exports, "resolveOAuthAccessCode", { enumerable: true, get: function () { return login_js_1.resolveOAuthAccessCode; } });
|
|
10
|
-
Object.defineProperty(exports, "isLoggedIn", { enumerable: true, get: function () { return login_js_1.isLoggedIn; } });
|
|
11
|
-
Object.defineProperty(exports, "buildLoginUrl", { enumerable: true, get: function () { return login_js_1.buildLoginUrl; } });
|
|
12
|
-
var session_js_1 = require("../shared/lib/session.js");
|
|
13
|
-
Object.defineProperty(exports, "getUser", { enumerable: true, get: function () { return session_js_1.getUser; } });
|
|
14
|
-
Object.defineProperty(exports, "getTokens", { enumerable: true, get: function () { return session_js_1.getTokens; } });
|
|
15
|
-
var refresh_js_1 = require("../server/refresh.js");
|
|
16
|
-
Object.defineProperty(exports, "refreshTokens", { enumerable: true, get: function () { return refresh_js_1.refreshTokens; } });
|
|
17
|
-
var logout_js_1 = require("../server/logout.js");
|
|
18
|
-
Object.defineProperty(exports, "buildLogoutRedirectUrl", { enumerable: true, get: function () { return logout_js_1.buildLogoutRedirectUrl; } });
|
|
19
|
-
var util_js_1 = require("../shared/lib/util.js");
|
|
20
|
-
Object.defineProperty(exports, "clearTokens", { enumerable: true, get: function () { return util_js_1.clearTokens; } });
|
|
21
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/server/index.ts"],"names":[],"mappings":";;;AAAA,gDAAiD;AACjD,IAAA,uBAAY,GAAE,CAAC;AAEf,sDAAwD;AAA/C,2GAAA,aAAa,OAAA;AAKtB,8CAI2B;AAHzB,kHAAA,sBAAsB,OAAA;AACtB,sGAAA,UAAU,OAAA;AACV,yGAAA,aAAa,OAAA;AAGf,sDAA6D;AAApD,qGAAA,OAAO,OAAA;AAAE,uGAAA,SAAS,OAAA;AAC3B,kDAAoD;AAA3C,2GAAA,aAAa,OAAA;AACtB,gDAA4D;AAAnD,mHAAA,sBAAsB,OAAA;AAC/B,gDAAmD;AAA1C,sGAAA,WAAW,OAAA","sourcesContent":["import { printVersion } from \"@/shared/index.js\";\nprintVersion();\n\nexport { CookieStorage } from \"@/shared/lib/storage.js\";\nexport type {\n SessionStorage,\n CookieStorageSettings,\n} from \"@/shared/lib/storage.js\";\nexport {\n resolveOAuthAccessCode,\n isLoggedIn,\n buildLoginUrl,\n} from \"@/server/login.js\";\nexport type { AuthConfig } from \"@/server/config.js\";\nexport { getUser, getTokens } from \"@/shared/lib/session.js\";\nexport { refreshTokens } from \"@/server/refresh.js\";\nexport { buildLogoutRedirectUrl } from \"@/server/logout.js\";\nexport { clearTokens } from \"@/shared/lib/util.js\";\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"login.d.ts","sourceRoot":"","sources":["../../../src/server/login.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAC;AAKrE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAErD;;;;;;GAMG;AACH,wBAAsB,sBAAsB,CAC1C,IAAI,EAAE,MAAM,EACZ,KAAK,EAAE,MAAM,EACb,OAAO,EAAE,WAAW,EACpB,MAAM,EAAE,UAAU,GACjB,OAAO,CAAC,qBAAqB,CAAC,CAWhC;AAED,wBAAsB,UAAU,CAAC,OAAO,EAAE,WAAW,GAAG,OAAO,CAAC,OAAO,CAAC,CAEvE;AAED,wBAAsB,aAAa,CACjC,MAAM,EAAE,IAAI,CAAC,UAAU,EAAE,UAAU,GAAG,aAAa,CAAC,GAClD,OAAO,CAAC,IAAI,CAAC,UAAU,EAAE,aAAa,CAAC,CAAC,GAAG;IACzC,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,EACH,OAAO,EAAE,WAAW,GACnB,OAAO,CAAC,GAAG,CAAC,CAed"}
|
package/dist/cjs/server/login.js
DELETED
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.resolveOAuthAccessCode = resolveOAuthAccessCode;
|
|
4
|
-
exports.isLoggedIn = isLoggedIn;
|
|
5
|
-
exports.buildLoginUrl = buildLoginUrl;
|
|
6
|
-
const constants_js_1 = require("../constants.js");
|
|
7
|
-
const AuthenticationService_js_1 = require("../services/AuthenticationService.js");
|
|
8
|
-
const PKCE_js_1 = require("../services/PKCE.js");
|
|
9
|
-
const ServerAuthenticationResolver_js_1 = require("../server/ServerAuthenticationResolver.js");
|
|
10
|
-
/**
|
|
11
|
-
* Resolve an OAuth access code to a set of OIDC tokens
|
|
12
|
-
* @param code The access code, typically from a query parameter in the redirect url
|
|
13
|
-
* @param state The oauth random state string, used to distinguish between requests. Typically also passed in the redirect url
|
|
14
|
-
* @param storage The place that this server uses to store session data (e.g. a cookie store)
|
|
15
|
-
* @param config Oauth Server configuration
|
|
16
|
-
*/
|
|
17
|
-
async function resolveOAuthAccessCode(code, state, storage, config) {
|
|
18
|
-
const authSessionService = await ServerAuthenticationResolver_js_1.ServerAuthenticationResolver.build({
|
|
19
|
-
...config,
|
|
20
|
-
oauthServer: config.oauthServer ?? constants_js_1.DEFAULT_AUTH_SERVER,
|
|
21
|
-
}, storage, config.endpointOverrides);
|
|
22
|
-
return authSessionService.tokenExchange(code, state);
|
|
23
|
-
}
|
|
24
|
-
async function isLoggedIn(storage) {
|
|
25
|
-
return !!(await storage.get("id_token"));
|
|
26
|
-
}
|
|
27
|
-
async function buildLoginUrl(config, storage) {
|
|
28
|
-
// generate a random state if not provided
|
|
29
|
-
const state = config.state ?? Math.random().toString(36).substring(2);
|
|
30
|
-
const scopes = config.scopes ?? constants_js_1.DEFAULT_SCOPES;
|
|
31
|
-
const pkceProducer = new PKCE_js_1.GenericPublicClientPKCEProducer(storage);
|
|
32
|
-
const authInitiator = new AuthenticationService_js_1.GenericAuthenticationInitiator({
|
|
33
|
-
...config,
|
|
34
|
-
state,
|
|
35
|
-
scopes,
|
|
36
|
-
oauthServer: config.oauthServer ?? constants_js_1.DEFAULT_AUTH_SERVER,
|
|
37
|
-
// When retrieving the PKCE challenge on the server-side, we produce it and store it in the session
|
|
38
|
-
pkceConsumer: pkceProducer,
|
|
39
|
-
});
|
|
40
|
-
return authInitiator.signIn();
|
|
41
|
-
}
|
|
42
|
-
//# sourceMappingURL=login.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"login.js","sourceRoot":"","sources":["../../../src/server/login.ts"],"names":[],"mappings":";;AAcA,wDAgBC;AAED,gCAEC;AAED,sCAuBC;AA1DD,iDAAqE;AACrE,kFAAqF;AACrF,gDAAqE;AACrE,8FAAwF;AAGxF;;;;;;GAMG;AACI,KAAK,UAAU,sBAAsB,CAC1C,IAAY,EACZ,KAAa,EACb,OAAoB,EACpB,MAAkB;IAElB,MAAM,kBAAkB,GAAG,MAAM,8DAA4B,CAAC,KAAK,CACjE;QACE,GAAG,MAAM;QACT,WAAW,EAAE,MAAM,CAAC,WAAW,IAAI,kCAAmB;KACvD,EACD,OAAO,EACP,MAAM,CAAC,iBAAiB,CACzB,CAAC;IAEF,OAAO,kBAAkB,CAAC,aAAa,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;AACvD,CAAC;AAEM,KAAK,UAAU,UAAU,CAAC,OAAoB;IACnD,OAAO,CAAC,CAAC,CAAC,MAAM,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC;AAC3C,CAAC;AAEM,KAAK,UAAU,aAAa,CACjC,MAKG,EACH,OAAoB;IAEpB,0CAA0C;IAC1C,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;IACtE,MAAM,MAAM,GAAG,MAAM,CAAC,MAAM,IAAI,6BAAc,CAAC;IAC/C,MAAM,YAAY,GAAG,IAAI,yCAA+B,CAAC,OAAO,CAAC,CAAC;IAClE,MAAM,aAAa,GAAG,IAAI,yDAA8B,CAAC;QACvD,GAAG,MAAM;QACT,KAAK;QACL,MAAM;QACN,WAAW,EAAE,MAAM,CAAC,WAAW,IAAI,kCAAmB;QACtD,mGAAmG;QACnG,YAAY,EAAE,YAAY;KAC3B,CAAC,CAAC;IAEH,OAAO,aAAa,CAAC,MAAM,EAAE,CAAC;AAChC,CAAC","sourcesContent":["import type { AuthStorage, OIDCTokenResponseBody } from \"@/types.js\";\nimport { DEFAULT_AUTH_SERVER, DEFAULT_SCOPES } from \"@/constants.js\";\nimport { GenericAuthenticationInitiator } from \"@/services/AuthenticationService.js\";\nimport { GenericPublicClientPKCEProducer } from \"@/services/PKCE.js\";\nimport { ServerAuthenticationResolver } from \"@/server/ServerAuthenticationResolver.js\";\nimport type { AuthConfig } from \"@/server/config.ts\";\n\n/**\n * Resolve an OAuth access code to a set of OIDC tokens\n * @param code The access code, typically from a query parameter in the redirect url\n * @param state The oauth random state string, used to distinguish between requests. Typically also passed in the redirect url\n * @param storage The place that this server uses to store session data (e.g. a cookie store)\n * @param config Oauth Server configuration\n */\nexport async function resolveOAuthAccessCode(\n code: string,\n state: string,\n storage: AuthStorage,\n config: AuthConfig,\n): Promise<OIDCTokenResponseBody> {\n const authSessionService = await ServerAuthenticationResolver.build(\n {\n ...config,\n oauthServer: config.oauthServer ?? DEFAULT_AUTH_SERVER,\n },\n storage,\n config.endpointOverrides,\n );\n\n return authSessionService.tokenExchange(code, state);\n}\n\nexport async function isLoggedIn(storage: AuthStorage): Promise<boolean> {\n return !!(await storage.get(\"id_token\"));\n}\n\nexport async function buildLoginUrl(\n config: Pick<AuthConfig, \"clientId\" | \"redirectUrl\"> &\n Partial<Pick<AuthConfig, \"oauthServer\">> & {\n scopes?: string[];\n state?: string;\n nonce?: string;\n },\n storage: AuthStorage,\n): Promise<URL> {\n // generate a random state if not provided\n const state = config.state ?? Math.random().toString(36).substring(2);\n const scopes = config.scopes ?? DEFAULT_SCOPES;\n const pkceProducer = new GenericPublicClientPKCEProducer(storage);\n const authInitiator = new GenericAuthenticationInitiator({\n ...config,\n state,\n scopes,\n oauthServer: config.oauthServer ?? DEFAULT_AUTH_SERVER,\n // When retrieving the PKCE challenge on the server-side, we produce it and store it in the session\n pkceConsumer: pkceProducer,\n });\n\n return authInitiator.signIn();\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"logout.d.ts","sourceRoot":"","sources":["../../../src/server/logout.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AACrD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAM9C,wBAAsB,sBAAsB,CAC1C,MAAM,EAAE,IAAI,CAAC,UAAU,EAAE,UAAU,GAAG,uBAAuB,CAAC,GAC5D,OAAO,CAAC,IAAI,CAAC,UAAU,EAAE,aAAa,CAAC,CAAC,GAAG;IACzC,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,EACH,OAAO,EAAE,WAAW,GACnB,OAAO,CAAC,GAAG,CAAC,CAkBd"}
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.buildLogoutRedirectUrl = buildLogoutRedirectUrl;
|
|
4
|
-
const constants_js_1 = require("../constants.js");
|
|
5
|
-
const PKCE_js_1 = require("../services/PKCE.js");
|
|
6
|
-
const AuthenticationService_js_1 = require("../services/AuthenticationService.js");
|
|
7
|
-
const types_js_1 = require("../shared/lib/types.js");
|
|
8
|
-
async function buildLogoutRedirectUrl(config, storage) {
|
|
9
|
-
// generate a random state if not provided
|
|
10
|
-
const state = config.state ?? Math.random().toString(36).substring(2);
|
|
11
|
-
const scopes = config.scopes ?? constants_js_1.DEFAULT_SCOPES;
|
|
12
|
-
const pkceProducer = new PKCE_js_1.GenericPublicClientPKCEProducer(storage);
|
|
13
|
-
const authInitiator = new AuthenticationService_js_1.GenericAuthenticationInitiator({
|
|
14
|
-
...config,
|
|
15
|
-
state,
|
|
16
|
-
scopes,
|
|
17
|
-
oauthServer: config.oauthServer ?? constants_js_1.DEFAULT_AUTH_SERVER,
|
|
18
|
-
pkceConsumer: pkceProducer,
|
|
19
|
-
redirectUrl: config.postLogoutRedirectUrl || "/",
|
|
20
|
-
});
|
|
21
|
-
const idToken = await storage.get(types_js_1.OAuthTokens.ID_TOKEN);
|
|
22
|
-
if (!idToken)
|
|
23
|
-
throw new Error("No id_token found in storage");
|
|
24
|
-
return authInitiator.signOut(idToken);
|
|
25
|
-
}
|
|
26
|
-
//# sourceMappingURL=logout.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"logout.js","sourceRoot":"","sources":["../../../src/server/logout.ts"],"names":[],"mappings":";;AAOA,wDAyBC;AA9BD,iDAAqE;AACrE,gDAAqE;AACrE,kFAAqF;AACrF,oDAAoD;AAE7C,KAAK,UAAU,sBAAsB,CAC1C,MAIG,EACH,OAAoB;IAEpB,0CAA0C;IAC1C,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;IACtE,MAAM,MAAM,GAAG,MAAM,CAAC,MAAM,IAAI,6BAAc,CAAC;IAC/C,MAAM,YAAY,GAAG,IAAI,yCAA+B,CAAC,OAAO,CAAC,CAAC;IAClE,MAAM,aAAa,GAAG,IAAI,yDAA8B,CAAC;QACvD,GAAG,MAAM;QACT,KAAK;QACL,MAAM;QACN,WAAW,EAAE,MAAM,CAAC,WAAW,IAAI,kCAAmB;QACtD,YAAY,EAAE,YAAY;QAC1B,WAAW,EAAE,MAAM,CAAC,qBAAqB,IAAI,GAAG;KACjD,CAAC,CAAC;IAEH,MAAM,OAAO,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC,sBAAW,CAAC,QAAQ,CAAC,CAAC;IACxD,IAAI,CAAC,OAAO;QAAE,MAAM,IAAI,KAAK,CAAC,8BAA8B,CAAC,CAAC;IAE9D,OAAO,aAAa,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;AACxC,CAAC","sourcesContent":["import type { AuthConfig } from \"@/server/config.js\";\nimport type { AuthStorage } from \"@/types.js\";\nimport { DEFAULT_AUTH_SERVER, DEFAULT_SCOPES } from \"@/constants.js\";\nimport { GenericPublicClientPKCEProducer } from \"@/services/PKCE.js\";\nimport { GenericAuthenticationInitiator } from \"@/services/AuthenticationService.js\";\nimport { OAuthTokens } from \"@/shared/lib/types.js\";\n\nexport async function buildLogoutRedirectUrl(\n config: Pick<AuthConfig, \"clientId\" | \"postLogoutRedirectUrl\"> &\n Partial<Pick<AuthConfig, \"oauthServer\">> & {\n scopes?: string[];\n state?: string;\n },\n storage: AuthStorage,\n): Promise<URL> {\n // generate a random state if not provided\n const state = config.state ?? Math.random().toString(36).substring(2);\n const scopes = config.scopes ?? DEFAULT_SCOPES;\n const pkceProducer = new GenericPublicClientPKCEProducer(storage);\n const authInitiator = new GenericAuthenticationInitiator({\n ...config,\n state,\n scopes,\n oauthServer: config.oauthServer ?? DEFAULT_AUTH_SERVER,\n pkceConsumer: pkceProducer,\n redirectUrl: config.postLogoutRedirectUrl || \"/\",\n });\n\n const idToken = await storage.get(OAuthTokens.ID_TOKEN);\n if (!idToken) throw new Error(\"No id_token found in storage\");\n\n return authInitiator.signOut(idToken);\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"refresh.d.ts","sourceRoot":"","sources":["../../../src/server/refresh.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAC;AAErE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAGrD;;GAEG;AACH,wBAAsB,aAAa,CACjC,OAAO,EAAE,WAAW,EACpB,MAAM,EAAE,UAAU,GACjB,OAAO,CAAC,qBAAqB,CAAC,CAWhC"}
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.refreshTokens = refreshTokens;
|
|
4
|
-
const constants_js_1 = require("../constants.js");
|
|
5
|
-
const AuthenticationRefresherImpl_js_1 = require("../shared/lib/AuthenticationRefresherImpl.js");
|
|
6
|
-
/**
|
|
7
|
-
* Refresh the current set of OIDC tokens
|
|
8
|
-
*/
|
|
9
|
-
async function refreshTokens(storage, config) {
|
|
10
|
-
const refresher = await AuthenticationRefresherImpl_js_1.AuthenticationRefresherImpl.build({
|
|
11
|
-
...config,
|
|
12
|
-
oauthServer: config.oauthServer ?? constants_js_1.DEFAULT_AUTH_SERVER,
|
|
13
|
-
}, storage, config.endpointOverrides);
|
|
14
|
-
return refresher.refreshTokens();
|
|
15
|
-
}
|
|
16
|
-
//# sourceMappingURL=refresh.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"refresh.js","sourceRoot":"","sources":["../../../src/server/refresh.ts"],"names":[],"mappings":";;AAQA,sCAcC;AArBD,iDAAqD;AAErD,gGAA0F;AAE1F;;GAEG;AACI,KAAK,UAAU,aAAa,CACjC,OAAoB,EACpB,MAAkB;IAElB,MAAM,SAAS,GAAG,MAAM,4DAA2B,CAAC,KAAK,CACvD;QACE,GAAG,MAAM;QACT,WAAW,EAAE,MAAM,CAAC,WAAW,IAAI,kCAAmB;KACvD,EACD,OAAO,EACP,MAAM,CAAC,iBAAiB,CACzB,CAAC;IAEF,OAAO,SAAS,CAAC,aAAa,EAAE,CAAC;AACnC,CAAC","sourcesContent":["import type { AuthStorage, OIDCTokenResponseBody } from \"@/types.js\";\nimport { DEFAULT_AUTH_SERVER } from \"@/constants.js\";\nimport type { AuthConfig } from \"@/server/config.ts\";\nimport { AuthenticationRefresherImpl } from \"@/shared/lib/AuthenticationRefresherImpl.js\";\n\n/**\n * Refresh the current set of OIDC tokens\n */\nexport async function refreshTokens(\n storage: AuthStorage,\n config: AuthConfig,\n): Promise<OIDCTokenResponseBody> {\n const refresher = await AuthenticationRefresherImpl.build(\n {\n ...config,\n oauthServer: config.oauthServer ?? DEFAULT_AUTH_SERVER,\n },\n storage,\n config.endpointOverrides,\n );\n\n return refresher.refreshTokens();\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"AuthenticationService.d.ts","sourceRoot":"","sources":["../../../src/services/AuthenticationService.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,374 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
// Proposals for revised versions of the SessionService AKA AuthSessionService
|
|
3
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
-
exports.BrowserAuthenticationService = exports.GenericAuthenticationInitiator = exports.BrowserAuthenticationInitiator = void 0;
|
|
5
|
-
const PKCE_js_1 = require("../services/PKCE.js");
|
|
6
|
-
const util_js_1 = require("../shared/lib/util.js");
|
|
7
|
-
const oauth_js_1 = require("../lib/oauth.js");
|
|
8
|
-
const oauth2_1 = require("oslo/oauth2");
|
|
9
|
-
const storage_js_1 = require("../browser/storage.js");
|
|
10
|
-
const types_js_1 = require("../services/types.js");
|
|
11
|
-
const windowUtil_js_1 = require("../lib/windowUtil.js");
|
|
12
|
-
const constants_js_1 = require("../constants.js");
|
|
13
|
-
const postMessage_js_1 = require("../lib/postMessage.js");
|
|
14
|
-
const session_js_1 = require("../shared/lib/session.js");
|
|
15
|
-
const UserSession_js_1 = require("../shared/lib/UserSession.js");
|
|
16
|
-
const iframeUtils_js_1 = require("../shared/lib/iframeUtils.js");
|
|
17
|
-
const defaultSetDesignOptions = (value) => {
|
|
18
|
-
localStorage.setItem("loginAppDesign", JSON.stringify(value));
|
|
19
|
-
};
|
|
20
|
-
/**
|
|
21
|
-
* An authentication initiator that works on a browser. Since this is just triggering
|
|
22
|
-
* login and logout, session data is not stored here.
|
|
23
|
-
* An associated AuthenticationResolver would be needed to get the session data.
|
|
24
|
-
* Storage is needed for the code verifier, this is the domain of the PKCEConsumer
|
|
25
|
-
* The storage used by the PKCEConsumer should be available to the AuthenticationResolver.
|
|
26
|
-
*
|
|
27
|
-
* Example usage:
|
|
28
|
-
*
|
|
29
|
-
* 1) Client-only SPA -eg a react app with no server:
|
|
30
|
-
* new BrowserAuthenticationInitiator({
|
|
31
|
-
* pkceConsumer: new BrowserPublicClientPKCEProducer(), // generate and retrieve the challenge client-side
|
|
32
|
-
* ... other config
|
|
33
|
-
* })
|
|
34
|
-
*
|
|
35
|
-
* 2) Client-side of a client/server app - eg a react app with a backend:
|
|
36
|
-
* new BrowserAuthenticationInitiator({
|
|
37
|
-
* pkceConsumer: new ConfidentialClientPKCEConsumer("https://myserver.com/pkce"), // get the challenge from the server
|
|
38
|
-
* ... other config
|
|
39
|
-
* })
|
|
40
|
-
*/
|
|
41
|
-
class BrowserAuthenticationInitiator {
|
|
42
|
-
setDesignOptions;
|
|
43
|
-
postMessageHandler = null;
|
|
44
|
-
config;
|
|
45
|
-
setDisplayMode(displayMode) {
|
|
46
|
-
this.config.displayMode = displayMode;
|
|
47
|
-
}
|
|
48
|
-
get displayMode() {
|
|
49
|
-
return this.config.displayMode;
|
|
50
|
-
}
|
|
51
|
-
get isServerTokenExchange() {
|
|
52
|
-
return this.config.pkceConsumer instanceof PKCE_js_1.ConfidentialClientPKCEConsumer;
|
|
53
|
-
}
|
|
54
|
-
get state() {
|
|
55
|
-
return (0, oauth_js_1.generateState)(this.config.displayMode, this.isServerTokenExchange);
|
|
56
|
-
}
|
|
57
|
-
constructor(config, setDesignOptions = defaultSetDesignOptions) {
|
|
58
|
-
this.setDesignOptions = setDesignOptions;
|
|
59
|
-
this.config = config;
|
|
60
|
-
this.postMessageHandler = (event) => {
|
|
61
|
-
const thisURL = new URL(window.location.href);
|
|
62
|
-
if (event.origin.endsWith("civic.com") ||
|
|
63
|
-
thisURL.hostname === "localhost") {
|
|
64
|
-
if (!(0, postMessage_js_1.validateLoginAppPostMessage)(event.data, this.config.clientId)) {
|
|
65
|
-
return;
|
|
66
|
-
}
|
|
67
|
-
const loginMessage = event.data;
|
|
68
|
-
if (loginMessage.type === "generatePopupFailed") {
|
|
69
|
-
this.handleLoginAppPopupFailed(loginMessage.data.url);
|
|
70
|
-
return;
|
|
71
|
-
}
|
|
72
|
-
if (loginMessage.type === "design") {
|
|
73
|
-
// TODO handle the design message
|
|
74
|
-
this.handleLoginAppDesignUpdate(loginMessage.data);
|
|
75
|
-
return;
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
};
|
|
79
|
-
window.addEventListener("message", this.postMessageHandler);
|
|
80
|
-
}
|
|
81
|
-
async handleLoginAppPopupFailed(redirectUrl) {
|
|
82
|
-
console.warn("Login app popup failed open a popup, using redirect mode instead...", redirectUrl);
|
|
83
|
-
window.location.href = redirectUrl;
|
|
84
|
-
}
|
|
85
|
-
async handleLoginAppDesignUpdate(options) {
|
|
86
|
-
this.setDesignOptions(options);
|
|
87
|
-
}
|
|
88
|
-
// Use the config (Client ID, scopes OAuth Server, Endpoints, PKCEConsumer) to generate a new login url
|
|
89
|
-
// and then use the display mode to decide how to send the user there
|
|
90
|
-
async signIn(iframeRef) {
|
|
91
|
-
const url = await (0, util_js_1.generateOauthLoginUrl)({
|
|
92
|
-
...this.config,
|
|
93
|
-
state: this.state,
|
|
94
|
-
});
|
|
95
|
-
if (this.config.displayMode === "iframe") {
|
|
96
|
-
const ref = (0, iframeUtils_js_1.getIframeRef)(iframeRef);
|
|
97
|
-
ref.setAttribute("src", url.toString());
|
|
98
|
-
}
|
|
99
|
-
if (this.config.displayMode === "redirect") {
|
|
100
|
-
window.location.href = url.toString();
|
|
101
|
-
}
|
|
102
|
-
if (this.config.displayMode === "new_tab") {
|
|
103
|
-
try {
|
|
104
|
-
const popupWindow = window.open(url.toString(), "_blank");
|
|
105
|
-
if (!popupWindow) {
|
|
106
|
-
throw new types_js_1.PopupError("Failed to open popup window");
|
|
107
|
-
}
|
|
108
|
-
// TODO handle the 'onclose' event to clean up and reset the authStatus
|
|
109
|
-
}
|
|
110
|
-
catch (error) {
|
|
111
|
-
console.error("popupWindow", error);
|
|
112
|
-
throw new types_js_1.PopupError("window.open has thrown: Failed to open popup window");
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
return url;
|
|
116
|
-
}
|
|
117
|
-
handleIframeUrlChange(iframe, expectedUrl) {
|
|
118
|
-
return new Promise((resolve, reject) => {
|
|
119
|
-
let interval = undefined;
|
|
120
|
-
let timeout = undefined;
|
|
121
|
-
const messageHandler = (event) => {
|
|
122
|
-
if (event.source !== iframe.contentWindow) {
|
|
123
|
-
// This message did not originate from the iframe. Ignore it.
|
|
124
|
-
return;
|
|
125
|
-
}
|
|
126
|
-
const message = event.data;
|
|
127
|
-
if (message.source === "civicloginApp" &&
|
|
128
|
-
(message.type === "auth_error" ||
|
|
129
|
-
message.type === "auth_error_try_again")) {
|
|
130
|
-
clearInterval(interval);
|
|
131
|
-
clearTimeout(timeout);
|
|
132
|
-
window.removeEventListener("message", messageHandler);
|
|
133
|
-
reject(new Error(message.data.error || "Authentication failed"));
|
|
134
|
-
return;
|
|
135
|
-
}
|
|
136
|
-
};
|
|
137
|
-
window.addEventListener("message", messageHandler);
|
|
138
|
-
// Keep the existing URL check logic for success case
|
|
139
|
-
const checkIframe = () => {
|
|
140
|
-
try {
|
|
141
|
-
const currentUrl = iframe.contentWindow?.location.href;
|
|
142
|
-
if (currentUrl?.includes(expectedUrl)) {
|
|
143
|
-
clearInterval(interval);
|
|
144
|
-
window.removeEventListener("message", messageHandler);
|
|
145
|
-
resolve();
|
|
146
|
-
}
|
|
147
|
-
}
|
|
148
|
-
catch {
|
|
149
|
-
// Ignore cross-origin errors
|
|
150
|
-
}
|
|
151
|
-
};
|
|
152
|
-
interval = setInterval(checkIframe, 100);
|
|
153
|
-
// Timeout after 10 seconds
|
|
154
|
-
timeout = setTimeout(() => {
|
|
155
|
-
clearInterval(interval);
|
|
156
|
-
window.removeEventListener("message", messageHandler);
|
|
157
|
-
reject(new Error("Timeout waiting for iframe URL change"));
|
|
158
|
-
}, 10000);
|
|
159
|
-
});
|
|
160
|
-
}
|
|
161
|
-
async signOut(idToken, iframeRef) {
|
|
162
|
-
let url;
|
|
163
|
-
const state = this.state;
|
|
164
|
-
if (this.isServerTokenExchange) {
|
|
165
|
-
if (!this.config.logoutUrl) {
|
|
166
|
-
throw new Error("logoutUrl is required for server token exchange");
|
|
167
|
-
}
|
|
168
|
-
url = new URL(this.config.logoutUrl, window.location.origin);
|
|
169
|
-
url.searchParams.append("state", state);
|
|
170
|
-
}
|
|
171
|
-
else {
|
|
172
|
-
if (!idToken) {
|
|
173
|
-
throw new Error("idToken is required for non-server token exchange");
|
|
174
|
-
}
|
|
175
|
-
url = await (0, util_js_1.generateOauthLogoutUrl)({
|
|
176
|
-
...this.config,
|
|
177
|
-
idToken,
|
|
178
|
-
state,
|
|
179
|
-
redirectUrl: this.config.logoutRedirectUrl,
|
|
180
|
-
});
|
|
181
|
-
}
|
|
182
|
-
if (this.config.displayMode === "iframe") {
|
|
183
|
-
const ref = (0, iframeUtils_js_1.getIframeRef)(iframeRef);
|
|
184
|
-
ref.setAttribute("src", url.toString());
|
|
185
|
-
try {
|
|
186
|
-
await this.handleIframeUrlChange(ref, this.config.logoutRedirectUrl);
|
|
187
|
-
}
|
|
188
|
-
catch (error) {
|
|
189
|
-
console.log("Failed to sign out", error);
|
|
190
|
-
// on logout error, trigger the logout-callback directly,
|
|
191
|
-
// if it is a logout from the server, so the the session is cleared
|
|
192
|
-
// and user can still sign out.
|
|
193
|
-
if (this.isServerTokenExchange) {
|
|
194
|
-
url = new URL(this.config.logoutRedirectUrl, window.location.origin);
|
|
195
|
-
url.searchParams.append("state", state);
|
|
196
|
-
url.searchParams.append("appUrl", window.location.origin);
|
|
197
|
-
ref.setAttribute("src", url.toString());
|
|
198
|
-
}
|
|
199
|
-
}
|
|
200
|
-
// Clear storage after successful detection
|
|
201
|
-
if (!this.isServerTokenExchange) {
|
|
202
|
-
const localStorage = new storage_js_1.LocalStorageAdapter();
|
|
203
|
-
await (0, util_js_1.clearTokens)(localStorage);
|
|
204
|
-
await (0, util_js_1.clearUser)(localStorage);
|
|
205
|
-
storage_js_1.LocalStorageAdapter.emitter.emit("signOut");
|
|
206
|
-
}
|
|
207
|
-
}
|
|
208
|
-
if (this.config.displayMode === "redirect") {
|
|
209
|
-
const localStorage = new storage_js_1.LocalStorageAdapter();
|
|
210
|
-
localStorage.set("logout_state", state);
|
|
211
|
-
window.location.href = url.toString();
|
|
212
|
-
}
|
|
213
|
-
if (this.config.displayMode === "new_tab") {
|
|
214
|
-
try {
|
|
215
|
-
const popupWindow = window.open(url.toString(), "_blank");
|
|
216
|
-
if (!popupWindow) {
|
|
217
|
-
throw new types_js_1.PopupError("Failed to open popup window");
|
|
218
|
-
}
|
|
219
|
-
}
|
|
220
|
-
catch (error) {
|
|
221
|
-
console.error("popupWindow", error);
|
|
222
|
-
throw new types_js_1.PopupError("window.open has thrown: Failed to open popup window");
|
|
223
|
-
}
|
|
224
|
-
}
|
|
225
|
-
return url;
|
|
226
|
-
}
|
|
227
|
-
cleanup() {
|
|
228
|
-
if (this.postMessageHandler) {
|
|
229
|
-
window.removeEventListener("message", this.postMessageHandler);
|
|
230
|
-
}
|
|
231
|
-
}
|
|
232
|
-
}
|
|
233
|
-
exports.BrowserAuthenticationInitiator = BrowserAuthenticationInitiator;
|
|
234
|
-
/** A general-purpose authentication initiator, that just generates urls, but lets
|
|
235
|
-
* the caller decide how to use them. This is useful for server-side applications
|
|
236
|
-
* that may serve this URL to their front-ends or just call them directly
|
|
237
|
-
*/
|
|
238
|
-
class GenericAuthenticationInitiator {
|
|
239
|
-
config;
|
|
240
|
-
constructor(config) {
|
|
241
|
-
this.config = config;
|
|
242
|
-
}
|
|
243
|
-
// Use the config (Client ID, scopes OAuth Server, Endpoints, PKCEConsumer) to generate a new login url
|
|
244
|
-
// and simply return the url
|
|
245
|
-
async signIn() {
|
|
246
|
-
return (0, util_js_1.generateOauthLoginUrl)(this.config);
|
|
247
|
-
}
|
|
248
|
-
async signOut(idToken) {
|
|
249
|
-
return (0, util_js_1.generateOauthLogoutUrl)({
|
|
250
|
-
...this.config,
|
|
251
|
-
idToken,
|
|
252
|
-
});
|
|
253
|
-
}
|
|
254
|
-
}
|
|
255
|
-
exports.GenericAuthenticationInitiator = GenericAuthenticationInitiator;
|
|
256
|
-
/**
|
|
257
|
-
* An authentication resolver that can run on the browser (i.e. a public client)
|
|
258
|
-
* It uses PKCE for security. PKCE and Session data are stored in local storage
|
|
259
|
-
*/
|
|
260
|
-
class BrowserAuthenticationService extends BrowserAuthenticationInitiator {
|
|
261
|
-
pkceProducer;
|
|
262
|
-
oauth2client;
|
|
263
|
-
endpoints;
|
|
264
|
-
// TODO WIP - perhaps we want to keep resolver and initiator separate here
|
|
265
|
-
constructor(config,
|
|
266
|
-
// Since we are running fully on the client, we produce as well as consume the PKCE challenge
|
|
267
|
-
pkceProducer = new PKCE_js_1.BrowserPublicClientPKCEProducer()) {
|
|
268
|
-
super({
|
|
269
|
-
...config,
|
|
270
|
-
// Store and retrieve the PKCE challenge in local storage
|
|
271
|
-
pkceConsumer: pkceProducer,
|
|
272
|
-
});
|
|
273
|
-
this.pkceProducer = pkceProducer;
|
|
274
|
-
}
|
|
275
|
-
// TODO too much code duplication here between the browser and the server variant.
|
|
276
|
-
// Suggestion for refactor: Standardise the config for AuthenticationResolvers and create a one-shot
|
|
277
|
-
// function for generating an oauth2client from it
|
|
278
|
-
async init() {
|
|
279
|
-
// resolve oauth config
|
|
280
|
-
this.endpoints = await (0, util_js_1.getEndpointsWithOverrides)(this.config.oauthServer, this.config.endpointOverrides);
|
|
281
|
-
this.oauth2client = new oauth2_1.OAuth2Client(this.config.clientId, this.endpoints.auth, this.endpoints.token, {
|
|
282
|
-
redirectURI: this.config.redirectUrl,
|
|
283
|
-
});
|
|
284
|
-
return this;
|
|
285
|
-
}
|
|
286
|
-
// Two responsibilities:
|
|
287
|
-
// 1. resolve the auth code to get the tokens (should use library code)
|
|
288
|
-
// 2. store the tokens in local storage
|
|
289
|
-
async tokenExchange(code, state) {
|
|
290
|
-
if (!this.oauth2client)
|
|
291
|
-
await this.init();
|
|
292
|
-
const codeVerifier = await this.pkceProducer.getCodeVerifier();
|
|
293
|
-
if (!codeVerifier)
|
|
294
|
-
throw new Error("Code verifier not found in storage");
|
|
295
|
-
// exchange auth code for tokens
|
|
296
|
-
const tokens = await (0, util_js_1.exchangeTokens)(code, state, this.pkceProducer, this.oauth2client, // clean up types here to avoid the ! operator
|
|
297
|
-
this.config.oauthServer, this.endpoints);
|
|
298
|
-
const clientStorage = new storage_js_1.LocalStorageAdapter();
|
|
299
|
-
await (0, util_js_1.storeTokens)(clientStorage, tokens);
|
|
300
|
-
const user = await (0, session_js_1.getUser)(clientStorage);
|
|
301
|
-
if (!user) {
|
|
302
|
-
throw new Error("Failed to get user info");
|
|
303
|
-
}
|
|
304
|
-
const userSession = new UserSession_js_1.GenericUserSession(clientStorage);
|
|
305
|
-
await userSession.set(user);
|
|
306
|
-
storage_js_1.LocalStorageAdapter.emitter.emit("signIn");
|
|
307
|
-
// cleanup the browser window if needed
|
|
308
|
-
const parsedDisplayMode = (0, oauth_js_1.displayModeFromState)(state, this.config.displayMode);
|
|
309
|
-
if (parsedDisplayMode === "new_tab") {
|
|
310
|
-
// Close the popup window
|
|
311
|
-
window.addEventListener("beforeunload", () => {
|
|
312
|
-
window?.opener?.focus();
|
|
313
|
-
});
|
|
314
|
-
window.close();
|
|
315
|
-
}
|
|
316
|
-
// these are the default oAuth params that get added to the URL in redirect which we want to remove if present
|
|
317
|
-
(0, windowUtil_js_1.removeParamsWithoutReload)(constants_js_1.DEFAULT_OAUTH_GET_PARAMS);
|
|
318
|
-
return tokens;
|
|
319
|
-
}
|
|
320
|
-
// Get the session data from local storage
|
|
321
|
-
async getSessionData() {
|
|
322
|
-
const storageData = await (0, util_js_1.retrieveTokens)(new storage_js_1.LocalStorageAdapter());
|
|
323
|
-
if (!storageData)
|
|
324
|
-
return null;
|
|
325
|
-
return {
|
|
326
|
-
authenticated: !!storageData.id_token,
|
|
327
|
-
idToken: storageData.id_token,
|
|
328
|
-
accessToken: storageData.access_token,
|
|
329
|
-
refreshToken: storageData.refresh_token,
|
|
330
|
-
accessTokenExpiresAt: storageData.access_token_expires_at,
|
|
331
|
-
};
|
|
332
|
-
}
|
|
333
|
-
async validateExistingSession() {
|
|
334
|
-
try {
|
|
335
|
-
const sessionData = await this.getSessionData();
|
|
336
|
-
if (!sessionData?.idToken || !sessionData.accessToken) {
|
|
337
|
-
const unAuthenticatedSession = { ...sessionData, authenticated: false };
|
|
338
|
-
// await clearTokens(new LocalStorageAdapter());
|
|
339
|
-
return unAuthenticatedSession;
|
|
340
|
-
}
|
|
341
|
-
if (!this.endpoints || !this.oauth2client)
|
|
342
|
-
await this.init();
|
|
343
|
-
// this function will throw if any of the tokens are invalid
|
|
344
|
-
await (0, util_js_1.validateOauth2Tokens)({
|
|
345
|
-
access_token: sessionData.accessToken,
|
|
346
|
-
id_token: sessionData.idToken,
|
|
347
|
-
refresh_token: sessionData.refreshToken,
|
|
348
|
-
access_token_expires_at: sessionData.accessTokenExpiresAt,
|
|
349
|
-
}, this.endpoints, this.oauth2client, this.config.oauthServer);
|
|
350
|
-
return sessionData;
|
|
351
|
-
}
|
|
352
|
-
catch (error) {
|
|
353
|
-
console.warn("Failed to validate existing tokens", error);
|
|
354
|
-
const unAuthenticatedSession = {
|
|
355
|
-
authenticated: false,
|
|
356
|
-
};
|
|
357
|
-
await (0, util_js_1.clearTokens)(new storage_js_1.LocalStorageAdapter());
|
|
358
|
-
return unAuthenticatedSession;
|
|
359
|
-
}
|
|
360
|
-
}
|
|
361
|
-
async getEndSessionEndpoint() {
|
|
362
|
-
if (!this.endpoints) {
|
|
363
|
-
return null;
|
|
364
|
-
}
|
|
365
|
-
return this.endpoints?.endsession;
|
|
366
|
-
}
|
|
367
|
-
static async build(config) {
|
|
368
|
-
const resolver = new BrowserAuthenticationService(config);
|
|
369
|
-
await resolver.init();
|
|
370
|
-
return resolver;
|
|
371
|
-
}
|
|
372
|
-
}
|
|
373
|
-
exports.BrowserAuthenticationService = BrowserAuthenticationService;
|
|
374
|
-
//# sourceMappingURL=AuthenticationService.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"AuthenticationService.js","sourceRoot":"","sources":["../../../src/services/AuthenticationService.ts"],"names":[],"mappings":"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","sourcesContent":["// Proposals for revised versions of the SessionService AKA AuthSessionService\n\nimport type {\n DisplayMode,\n Endpoints,\n IframeAuthMessage,\n LoginAppDesignOptions,\n LoginPostMessage,\n OIDCTokenResponseBody,\n SessionData,\n} from \"@/types.js\";\nimport {\n BrowserPublicClientPKCEProducer,\n ConfidentialClientPKCEConsumer,\n} from \"@/services/PKCE.js\";\nimport {\n clearTokens,\n clearUser,\n exchangeTokens,\n generateOauthLoginUrl,\n generateOauthLogoutUrl,\n getEndpointsWithOverrides,\n retrieveTokens,\n storeTokens,\n validateOauth2Tokens,\n} from \"@/shared/lib/util.js\";\nimport { displayModeFromState, generateState } from \"@/lib/oauth.js\";\nimport { OAuth2Client } from \"oslo/oauth2\";\nimport { LocalStorageAdapter } from \"@/browser/storage.js\";\nimport type {\n AuthenticationInitiator,\n AuthenticationResolver,\n PKCEConsumer,\n} from \"@/services/types.js\";\nimport { PopupError } from \"@/services/types.js\";\nimport { removeParamsWithoutReload } from \"@/lib/windowUtil.js\";\nimport { DEFAULT_OAUTH_GET_PARAMS } from \"@/constants.js\";\nimport { validateLoginAppPostMessage } from \"@/lib/postMessage.js\";\nimport { getUser } from \"@/shared/lib/session.js\";\nimport { GenericUserSession } from \"@/shared/lib/UserSession.js\";\nimport { getIframeRef } from \"@/shared/lib/iframeUtils.js\";\n\nexport type GenericAuthenticationInitiatorConfig = {\n clientId: string;\n redirectUrl: string;\n state: string;\n scopes: string[];\n oauthServer: string;\n nonce?: string;\n // the endpoints to use for the login (if not obtained from the auth server)\n endpointOverrides?: Partial<Endpoints>;\n // used to get the PKCE challenge\n pkceConsumer: PKCEConsumer;\n};\n\nexport type BrowserAuthenticationInitiatorConfig = Omit<\n GenericAuthenticationInitiatorConfig,\n \"state\"\n> & {\n logoutUrl?: string;\n logoutRedirectUrl: string;\n // determines whether to trigger the login/logout in an iframe, a new browser window, or redirect the current one.\n displayMode: DisplayMode;\n};\n\nconst defaultSetDesignOptions = (value: LoginAppDesignOptions) => {\n localStorage.setItem(\"loginAppDesign\", JSON.stringify(value));\n};\n/**\n * An authentication initiator that works on a browser. Since this is just triggering\n * login and logout, session data is not stored here.\n * An associated AuthenticationResolver would be needed to get the session data.\n * Storage is needed for the code verifier, this is the domain of the PKCEConsumer\n * The storage used by the PKCEConsumer should be available to the AuthenticationResolver.\n *\n * Example usage:\n *\n * 1) Client-only SPA -eg a react app with no server:\n * new BrowserAuthenticationInitiator({\n * pkceConsumer: new BrowserPublicClientPKCEProducer(), // generate and retrieve the challenge client-side\n * ... other config\n * })\n *\n * 2) Client-side of a client/server app - eg a react app with a backend:\n * new BrowserAuthenticationInitiator({\n * pkceConsumer: new ConfidentialClientPKCEConsumer(\"https://myserver.com/pkce\"), // get the challenge from the server\n * ... other config\n * })\n */\nexport class BrowserAuthenticationInitiator implements AuthenticationInitiator {\n private postMessageHandler: null | ((event: MessageEvent) => void) = null;\n\n protected config: BrowserAuthenticationInitiatorConfig;\n\n public setDisplayMode(displayMode: DisplayMode) {\n this.config.displayMode = displayMode;\n }\n\n get displayMode() {\n return this.config.displayMode;\n }\n\n get isServerTokenExchange() {\n return this.config.pkceConsumer instanceof ConfidentialClientPKCEConsumer;\n }\n get state() {\n return generateState(this.config.displayMode, this.isServerTokenExchange);\n }\n constructor(\n config: typeof this.config,\n readonly setDesignOptions = defaultSetDesignOptions,\n ) {\n this.config = config;\n\n this.postMessageHandler = (event: MessageEvent) => {\n const thisURL = new URL(window.location.href);\n if (\n event.origin.endsWith(\"civic.com\") ||\n thisURL.hostname === \"localhost\"\n ) {\n if (!validateLoginAppPostMessage(event.data, this.config.clientId)) {\n return;\n }\n const loginMessage = event.data as LoginPostMessage;\n if (loginMessage.type === \"generatePopupFailed\") {\n this.handleLoginAppPopupFailed(\n (loginMessage.data as { url: string }).url,\n );\n return;\n }\n if (loginMessage.type === \"design\") {\n // TODO handle the design message\n this.handleLoginAppDesignUpdate(\n loginMessage.data as LoginAppDesignOptions,\n );\n return;\n }\n }\n };\n\n window.addEventListener(\"message\", this.postMessageHandler);\n }\n\n async handleLoginAppPopupFailed(redirectUrl: string) {\n console.warn(\n \"Login app popup failed open a popup, using redirect mode instead...\",\n redirectUrl,\n );\n window.location.href = redirectUrl;\n }\n\n async handleLoginAppDesignUpdate(options: LoginAppDesignOptions) {\n this.setDesignOptions(options);\n }\n\n // Use the config (Client ID, scopes OAuth Server, Endpoints, PKCEConsumer) to generate a new login url\n // and then use the display mode to decide how to send the user there\n async signIn(iframeRef: HTMLIFrameElement | null): Promise<URL> {\n const url = await generateOauthLoginUrl({\n ...this.config,\n state: this.state,\n });\n\n if (this.config.displayMode === \"iframe\") {\n const ref = getIframeRef(iframeRef);\n ref.setAttribute(\"src\", url.toString());\n }\n\n if (this.config.displayMode === \"redirect\") {\n window.location.href = url.toString();\n }\n\n if (this.config.displayMode === \"new_tab\") {\n try {\n const popupWindow = window.open(url.toString(), \"_blank\");\n if (!popupWindow) {\n throw new PopupError(\"Failed to open popup window\");\n }\n // TODO handle the 'onclose' event to clean up and reset the authStatus\n } catch (error) {\n console.error(\"popupWindow\", error);\n throw new PopupError(\n \"window.open has thrown: Failed to open popup window\",\n );\n }\n }\n\n return url;\n }\n\n protected handleIframeUrlChange(\n iframe: HTMLIFrameElement,\n expectedUrl: string,\n ): Promise<void> {\n return new Promise((resolve, reject) => {\n let interval: NodeJS.Timeout | undefined = undefined;\n let timeout: NodeJS.Timeout | undefined = undefined;\n\n const messageHandler = (event: MessageEvent) => {\n if (event.source !== iframe.contentWindow) {\n // This message did not originate from the iframe. Ignore it.\n return;\n }\n\n const message = event.data as IframeAuthMessage;\n\n if (\n message.source === \"civicloginApp\" &&\n (message.type === \"auth_error\" ||\n message.type === \"auth_error_try_again\")\n ) {\n clearInterval(interval);\n clearTimeout(timeout);\n window.removeEventListener(\"message\", messageHandler);\n reject(new Error(message.data.error || \"Authentication failed\"));\n return;\n }\n };\n\n window.addEventListener(\"message\", messageHandler);\n\n // Keep the existing URL check logic for success case\n const checkIframe = () => {\n try {\n const currentUrl = iframe.contentWindow?.location.href;\n if (currentUrl?.includes(expectedUrl)) {\n clearInterval(interval);\n window.removeEventListener(\"message\", messageHandler);\n resolve();\n }\n } catch {\n // Ignore cross-origin errors\n }\n };\n\n interval = setInterval(checkIframe, 100);\n\n // Timeout after 10 seconds\n timeout = setTimeout(() => {\n clearInterval(interval);\n window.removeEventListener(\"message\", messageHandler);\n reject(new Error(\"Timeout waiting for iframe URL change\"));\n }, 10000);\n });\n }\n\n async signOut(\n idToken: string | undefined,\n iframeRef: HTMLIFrameElement | null,\n ): Promise<URL> {\n let url;\n const state = this.state;\n if (this.isServerTokenExchange) {\n if (!this.config.logoutUrl) {\n throw new Error(\"logoutUrl is required for server token exchange\");\n }\n url = new URL(this.config.logoutUrl, window.location.origin);\n url.searchParams.append(\"state\", state);\n } else {\n if (!idToken) {\n throw new Error(\"idToken is required for non-server token exchange\");\n }\n url = await generateOauthLogoutUrl({\n ...this.config,\n idToken,\n state,\n redirectUrl: this.config.logoutRedirectUrl,\n });\n }\n\n if (this.config.displayMode === \"iframe\") {\n const ref = getIframeRef(iframeRef);\n ref.setAttribute(\"src\", url.toString());\n\n try {\n await this.handleIframeUrlChange(ref, this.config.logoutRedirectUrl);\n } catch (error) {\n console.log(\"Failed to sign out\", error);\n // on logout error, trigger the logout-callback directly,\n // if it is a logout from the server, so the the session is cleared\n // and user can still sign out.\n if (this.isServerTokenExchange) {\n url = new URL(this.config.logoutRedirectUrl, window.location.origin);\n url.searchParams.append(\"state\", state);\n url.searchParams.append(\"appUrl\", window.location.origin);\n ref.setAttribute(\"src\", url.toString());\n }\n }\n\n // Clear storage after successful detection\n if (!this.isServerTokenExchange) {\n const localStorage = new LocalStorageAdapter();\n await clearTokens(localStorage);\n await clearUser(localStorage);\n LocalStorageAdapter.emitter.emit(\"signOut\");\n }\n }\n\n if (this.config.displayMode === \"redirect\") {\n const localStorage = new LocalStorageAdapter();\n localStorage.set(\"logout_state\", state);\n window.location.href = url.toString();\n }\n\n if (this.config.displayMode === \"new_tab\") {\n try {\n const popupWindow = window.open(url.toString(), \"_blank\");\n if (!popupWindow) {\n throw new PopupError(\"Failed to open popup window\");\n }\n } catch (error) {\n console.error(\"popupWindow\", error);\n throw new PopupError(\n \"window.open has thrown: Failed to open popup window\",\n );\n }\n }\n\n return url;\n }\n\n cleanup() {\n if (this.postMessageHandler) {\n window.removeEventListener(\"message\", this.postMessageHandler);\n }\n }\n}\n\n/** A general-purpose authentication initiator, that just generates urls, but lets\n * the caller decide how to use them. This is useful for server-side applications\n * that may serve this URL to their front-ends or just call them directly\n */\nexport class GenericAuthenticationInitiator implements AuthenticationInitiator {\n protected config: GenericAuthenticationInitiatorConfig;\n\n constructor(config: typeof this.config) {\n this.config = config;\n }\n\n // Use the config (Client ID, scopes OAuth Server, Endpoints, PKCEConsumer) to generate a new login url\n // and simply return the url\n async signIn(): Promise<URL> {\n return generateOauthLoginUrl(this.config);\n }\n\n async signOut(idToken: string): Promise<URL> {\n return generateOauthLogoutUrl({\n ...this.config,\n idToken,\n });\n }\n}\n\ntype BrowserAuthenticationConfig = {\n clientId: string;\n redirectUrl: string;\n logoutUrl?: string;\n logoutRedirectUrl: string;\n scopes: string[];\n oauthServer: string;\n endpointOverrides?: Partial<Endpoints>;\n displayMode: DisplayMode;\n};\n\n/**\n * An authentication resolver that can run on the browser (i.e. a public client)\n * It uses PKCE for security. PKCE and Session data are stored in local storage\n */\nexport class BrowserAuthenticationService extends BrowserAuthenticationInitiator {\n private oauth2client: OAuth2Client | undefined;\n private endpoints: Endpoints | undefined;\n\n // TODO WIP - perhaps we want to keep resolver and initiator separate here\n constructor(\n config: BrowserAuthenticationConfig,\n // Since we are running fully on the client, we produce as well as consume the PKCE challenge\n protected pkceProducer = new BrowserPublicClientPKCEProducer(),\n ) {\n super({\n ...config,\n // Store and retrieve the PKCE challenge in local storage\n pkceConsumer: pkceProducer,\n });\n }\n\n // TODO too much code duplication here between the browser and the server variant.\n // Suggestion for refactor: Standardise the config for AuthenticationResolvers and create a one-shot\n // function for generating an oauth2client from it\n async init(): Promise<this> {\n // resolve oauth config\n this.endpoints = await getEndpointsWithOverrides(\n this.config.oauthServer,\n this.config.endpointOverrides,\n );\n this.oauth2client = new OAuth2Client(\n this.config.clientId,\n this.endpoints.auth,\n this.endpoints.token,\n {\n redirectURI: this.config.redirectUrl,\n },\n );\n\n return this;\n }\n\n // Two responsibilities:\n // 1. resolve the auth code to get the tokens (should use library code)\n // 2. store the tokens in local storage\n async tokenExchange(\n code: string,\n state: string,\n ): Promise<OIDCTokenResponseBody> {\n if (!this.oauth2client) await this.init();\n const codeVerifier = await this.pkceProducer.getCodeVerifier();\n if (!codeVerifier) throw new Error(\"Code verifier not found in storage\");\n\n // exchange auth code for tokens\n const tokens = await exchangeTokens(\n code,\n state,\n this.pkceProducer,\n this.oauth2client!, // clean up types here to avoid the ! operator\n this.config.oauthServer,\n this.endpoints!, // clean up types here to avoid the ! operator\n );\n const clientStorage = new LocalStorageAdapter();\n await storeTokens(clientStorage, tokens);\n const user = await getUser(clientStorage);\n if (!user) {\n throw new Error(\"Failed to get user info\");\n }\n const userSession = new GenericUserSession(clientStorage);\n await userSession.set(user);\n LocalStorageAdapter.emitter.emit(\"signIn\");\n // cleanup the browser window if needed\n const parsedDisplayMode = displayModeFromState(\n state,\n this.config.displayMode,\n );\n\n if (parsedDisplayMode === \"new_tab\") {\n // Close the popup window\n window.addEventListener(\"beforeunload\", () => {\n window?.opener?.focus();\n });\n window.close();\n }\n // these are the default oAuth params that get added to the URL in redirect which we want to remove if present\n removeParamsWithoutReload(DEFAULT_OAUTH_GET_PARAMS);\n return tokens;\n }\n\n // Get the session data from local storage\n async getSessionData(): Promise<SessionData | null> {\n const storageData = await retrieveTokens(new LocalStorageAdapter());\n\n if (!storageData) return null;\n\n return {\n authenticated: !!storageData.id_token,\n idToken: storageData.id_token,\n accessToken: storageData.access_token,\n refreshToken: storageData.refresh_token,\n accessTokenExpiresAt: storageData.access_token_expires_at,\n };\n }\n\n async validateExistingSession(): Promise<SessionData> {\n try {\n const sessionData = await this.getSessionData();\n if (!sessionData?.idToken || !sessionData.accessToken) {\n const unAuthenticatedSession = { ...sessionData, authenticated: false };\n // await clearTokens(new LocalStorageAdapter());\n return unAuthenticatedSession;\n }\n if (!this.endpoints || !this.oauth2client) await this.init();\n\n // this function will throw if any of the tokens are invalid\n await validateOauth2Tokens(\n {\n access_token: sessionData.accessToken,\n id_token: sessionData.idToken,\n refresh_token: sessionData.refreshToken,\n access_token_expires_at: sessionData.accessTokenExpiresAt,\n },\n this.endpoints!,\n this.oauth2client!,\n this.config.oauthServer,\n );\n return sessionData;\n } catch (error) {\n console.warn(\"Failed to validate existing tokens\", error);\n const unAuthenticatedSession = {\n authenticated: false,\n };\n await clearTokens(new LocalStorageAdapter());\n return unAuthenticatedSession;\n }\n }\n\n async getEndSessionEndpoint(): Promise<string | null> {\n if (!this.endpoints) {\n return null;\n }\n return this.endpoints?.endsession;\n }\n\n static async build(\n config: BrowserAuthenticationConfig,\n ): Promise<AuthenticationResolver> {\n const resolver = new BrowserAuthenticationService(config);\n await resolver.init();\n\n return resolver;\n }\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"PKCE.d.ts","sourceRoot":"","sources":["../../../src/services/PKCE.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACtE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAG9C,0EAA0E;AAC1E,qBAAa,8BAA+B,YAAW,YAAY;IACrD,OAAO,CAAC,qBAAqB;gBAArB,qBAAqB,EAAE,MAAM;IAC3C,gBAAgB,IAAI,OAAO,CAAC,MAAM,CAAC;CAO1C;AAED,8GAA8G;AAC9G,qBAAa,+BAAgC,YAAW,YAAY;IACtD,OAAO,CAAC,OAAO;gBAAP,OAAO,EAAE,WAAW;IAIlC,gBAAgB,IAAI,OAAO,CAAC,MAAM,CAAC;IASnC,eAAe,IAAI,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;CAGhD;AAED,wFAAwF;AACxF,qBAAa,+BAAgC,SAAQ,+BAA+B;;CAInF"}
|