@zengenti/contensis-react-base 4.0.0-beta.2 → 4.0.0-beta.4
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/LICENSE +7 -0
- package/README.md +18 -478
- package/cjs/{App-b56aca04.js → App-DXro6av4.js} +215 -234
- package/cjs/App-DXro6av4.js.map +1 -0
- package/cjs/{ChangePassword.container-ae35785e.js → ChangePassword.container-ECjEXixF.js} +209 -286
- package/cjs/ChangePassword.container-ECjEXixF.js.map +1 -0
- package/cjs/CookieHelper.class-C3Eqoze9.js +471 -0
- package/cjs/CookieHelper.class-C3Eqoze9.js.map +1 -0
- package/cjs/{RouteLoader-c06dccd5.js → RouteLoader-BFc-Wl6M.js} +55 -68
- package/cjs/RouteLoader-BFc-Wl6M.js.map +1 -0
- package/cjs/{ContensisDeliveryApi-4fcf049d.js → SSRContext-CFeZxG9H.js} +165 -119
- package/cjs/SSRContext-CFeZxG9H.js.map +1 -0
- package/cjs/{ToJs-a8d8f3f0.js → ToJs-C9jwV7YB.js} +26 -80
- package/cjs/ToJs-C9jwV7YB.js.map +1 -0
- package/cjs/{_commonjsHelpers-b3309d7b.js → _commonjsHelpers-BJu3ubxk.js} +1 -1
- package/cjs/_commonjsHelpers-BJu3ubxk.js.map +1 -0
- package/cjs/client.js +67 -65
- package/cjs/client.js.map +1 -1
- package/cjs/contensis-react-base.js +387 -3294
- package/cjs/contensis-react-base.js.map +1 -1
- package/cjs/{fromJSLeaveImmer-e74c673c.js → fromJSLeaveImmer-Blvlk4t2.js} +3 -7
- package/{esm/fromJSLeaveImmer-0114ffcf.js.map → cjs/fromJSLeaveImmer-Blvlk4t2.js.map} +1 -1
- package/cjs/redux.js +19 -20
- package/cjs/redux.js.map +1 -1
- package/cjs/routing.js +13 -6
- package/cjs/routing.js.map +1 -1
- package/cjs/sagas-CbZhaRNd.js +6010 -0
- package/cjs/sagas-CbZhaRNd.js.map +1 -0
- package/cjs/search.js +105 -305
- package/cjs/search.js.map +1 -1
- package/cjs/selectors-wCs5fHD4.js +460 -0
- package/cjs/selectors-wCs5fHD4.js.map +1 -0
- package/cjs/{version-34d91f68.js → store-D07FOXvM.js} +44 -114
- package/cjs/store-D07FOXvM.js.map +1 -0
- package/cjs/{urls-6fcaf4c6.js → urls-DVIwGZmd.js} +1 -1
- package/{esm/urls-eac9a747.js.map → cjs/urls-DVIwGZmd.js.map} +1 -1
- package/cjs/user.js +12 -20
- package/cjs/user.js.map +1 -1
- package/cjs/util.js +109 -116
- package/cjs/util.js.map +1 -1
- package/cjs/{version-a410c88e.js → version-B7XFkBhY.js} +19 -22
- package/{esm/version-9f29becb.js.map → cjs/version-B7XFkBhY.js.map} +1 -1
- package/cjs/version-CM-bJ62L.js +20 -0
- package/cjs/version-CM-bJ62L.js.map +1 -0
- package/esm/{App-83107d7e.js → App-CIlf4cl4.js} +176 -195
- package/esm/App-CIlf4cl4.js.map +1 -0
- package/esm/{ChangePassword.container-76fd5e9b.js → ChangePassword.container-C0tFq0Tf.js} +191 -250
- package/esm/ChangePassword.container-C0tFq0Tf.js.map +1 -0
- package/esm/CookieHelper.class-FTURFpz3.js +464 -0
- package/esm/CookieHelper.class-FTURFpz3.js.map +1 -0
- package/esm/{RouteLoader-29fd689a.js → RouteLoader-D7HmVx5l.js} +40 -53
- package/esm/RouteLoader-D7HmVx5l.js.map +1 -0
- package/esm/{ContensisDeliveryApi-fe57a037.js → SSRContext-CkiWIvde.js} +159 -120
- package/esm/SSRContext-CkiWIvde.js.map +1 -0
- package/esm/{ToJs-df57f31d.js → ToJs-CpPNdcXS.js} +24 -77
- package/esm/ToJs-CpPNdcXS.js.map +1 -0
- package/esm/{_commonjsHelpers-1789f0cf.js → _commonjsHelpers-BFTU3MAI.js} +1 -1
- package/esm/_commonjsHelpers-BFTU3MAI.js.map +1 -0
- package/esm/client.js +55 -53
- package/esm/client.js.map +1 -1
- package/esm/contensis-react-base.js +318 -3223
- package/esm/contensis-react-base.js.map +1 -1
- package/esm/{fromJSLeaveImmer-0114ffcf.js → fromJSLeaveImmer-C_YACmOf.js} +2 -6
- package/{cjs/fromJSLeaveImmer-e74c673c.js.map → esm/fromJSLeaveImmer-C_YACmOf.js.map} +1 -1
- package/esm/redux.js +10 -9
- package/esm/redux.js.map +1 -1
- package/esm/routing.js +13 -4
- package/esm/routing.js.map +1 -1
- package/esm/sagas-xJU-zOpn.js +5916 -0
- package/esm/sagas-xJU-zOpn.js.map +1 -0
- package/esm/search.js +113 -311
- package/esm/search.js.map +1 -1
- package/esm/selectors-CBdCY0u3.js +396 -0
- package/esm/selectors-CBdCY0u3.js.map +1 -0
- package/esm/{version-3d9911e2.js → store-v2gyr6u2.js} +38 -85
- package/esm/store-v2gyr6u2.js.map +1 -0
- package/esm/{urls-eac9a747.js → urls-DfCisos-.js} +1 -1
- package/{cjs/urls-6fcaf4c6.js.map → esm/urls-DfCisos-.js.map} +1 -1
- package/esm/user.js +7 -13
- package/esm/user.js.map +1 -1
- package/esm/util.js +67 -75
- package/esm/util.js.map +1 -1
- package/esm/version-D773TD9j.js +15 -0
- package/esm/version-D773TD9j.js.map +1 -0
- package/esm/{version-9f29becb.js → version-DvjTUbcA.js} +6 -9
- package/{cjs/version-a410c88e.js.map → esm/version-DvjTUbcA.js.map} +1 -1
- package/models/app/App.d.ts +1 -1
- package/models/app/pages/VersionInfo/components/VersionInfo.d.ts +4 -1
- package/models/app/pages/VersionInfo/components/VersionInfo.styled.d.ts +2 -1
- package/models/client/client.d.ts +1 -1
- package/models/index.d.ts +1 -2
- package/models/models/AppRouteProps.d.ts +11 -0
- package/models/{redux/appstate.d.ts → models/AppState.d.ts} +3 -3
- package/models/models/ContentTypeMapping.d.ts +89 -0
- package/models/models/EntryMapper.d.ts +3 -0
- package/models/models/GetRouteActionArgs.d.ts +15 -0
- package/models/models/MatchedRoute.d.ts +4 -0
- package/models/models/ReduxInjector.d.ts +5 -0
- package/models/models/RequireLogin.d.ts +6 -0
- package/models/models/RouteComponent.d.ts +4 -0
- package/models/models/RouteComponentProps.d.ts +9 -0
- package/models/models/RouteLoaderProps.d.ts +9 -0
- package/models/models/RouteNode.d.ts +5 -0
- package/models/models/SSRContext.d.ts +11 -0
- package/models/models/StaticRoute.d.ts +61 -0
- package/models/models/WithEvents.d.ts +58 -0
- package/models/models/config/AppConfig.d.ts +12 -0
- package/models/{config.d.ts → models/config/ServerConfig.d.ts} +3 -12
- package/models/models/config/StateType.d.ts +1 -0
- package/models/models/config/index.d.ts +3 -0
- package/models/models/index.d.ts +16 -0
- package/models/redux/actions/index.d.ts +2 -2
- package/models/redux/sagas/navigation.d.ts +1 -3
- package/models/redux/selectors/index.d.ts +2 -2
- package/models/redux/store/injectors.d.ts +16 -4
- package/models/redux/store/store.d.ts +10 -4
- package/models/redux/types/index.d.ts +2 -2
- package/models/redux/types/navigation.d.ts +3 -3
- package/models/redux/types/version.d.ts +2 -2
- package/models/routing/components/Redirect.d.ts +1 -1
- package/models/routing/components/RouteLoader.d.ts +1 -1
- package/models/routing/components/StaticRouteLoader.d.ts +1 -1
- package/models/routing/components/Status.d.ts +1 -1
- package/models/routing/redux/actions.d.ts +3 -4
- package/models/routing/redux/selectors.d.ts +2 -2
- package/models/routing/redux/types.d.ts +11 -11
- package/models/routing/util/find-contenttype-mapping.d.ts +1 -1
- package/models/routing/util/queries.d.ts +2 -2
- package/models/search/containers/withListing.d.ts +4 -1
- package/models/search/containers/withSearch.d.ts +4 -1
- package/models/search/models/Queries.d.ts +4 -2
- package/models/search/models/Search.d.ts +8 -1
- package/models/search/models/SearchActions.d.ts +3 -2
- package/models/search/models/SearchState.d.ts +5 -1
- package/models/search/redux/reducers.d.ts +2 -257
- package/models/search/redux/schema.d.ts +1 -1
- package/models/search/redux/selectors.d.ts +5 -5
- package/models/search/search/ContensisDeliveryApi.d.ts +2 -2
- package/models/search/search/ToJs.d.ts +1 -1
- package/models/search/search/expressions.d.ts +3 -3
- package/models/search/search/util.d.ts +17 -2
- package/models/search/transformations/searchresult-to-state.mapper.d.ts +1 -2
- package/models/server/features/caching/cacheDuration.schema.d.ts +1 -0
- package/models/server/features/linkdepth-api/search.d.ts +1 -1
- package/models/server/features/static-assets/index.d.ts +1 -1
- package/models/server/internalServer.d.ts +1 -1
- package/models/server/util/bundles.d.ts +1 -1
- package/models/server/util/headers.d.ts +1 -1
- package/models/server/webApp.d.ts +1 -1
- package/models/user/components/Login.d.ts +1 -1
- package/models/user/components/LoginForm.d.ts +6 -6
- package/models/user/components/LogoutForm.d.ts +4 -4
- package/models/user/components.styled/Login.styled.d.ts +1 -1
- package/models/user/components.styled/LoginForm.styled.d.ts +1 -1
- package/models/user/hocs/withLogin.d.ts +4 -4
- package/models/user/hocs/withRegistration.d.ts +6 -3
- package/models/user/hooks/useLogin.d.ts +4 -4
- package/models/user/redux/actions.d.ts +7 -6
- package/models/user/redux/sagas/index.d.ts +1 -1
- package/models/user/redux/sagas/login.d.ts +5 -17
- package/models/user/redux/selectors.d.ts +1 -2
- package/models/user/redux/types.d.ts +21 -21
- package/models/user/state.d.ts +12 -0
- package/models/user/transformations/mapClientCredentials.d.ts +3 -1
- package/models/user/util/ContensisManagementApi.d.ts +10 -9
- package/models/user/util/CookieConstants.d.ts +1 -0
- package/models/user/util/CookieHelper.class.d.ts +8 -4
- package/models/user/util/LoginHelper.class.d.ts +25 -37
- package/models/user/util/OidcUserManager.d.ts +1 -1
- package/models/user/util/matchGroups.d.ts +1 -1
- package/models/util/CachedDeliveryApi.d.ts +11 -10
- package/models/util/ContensisDeliveryApi.d.ts +11 -7
- package/models/util/SSRContext.d.ts +29 -0
- package/models/util/index.d.ts +1 -0
- package/models/util/json-mapper.d.ts +4 -5
- package/package.json +71 -92
- package/cjs/App-b56aca04.js.map +0 -1
- package/cjs/ChangePassword.container-ae35785e.js.map +0 -1
- package/cjs/ContensisDeliveryApi-4fcf049d.js.map +0 -1
- package/cjs/CookieConstants-000427db.js +0 -10
- package/cjs/CookieConstants-000427db.js.map +0 -1
- package/cjs/RouteLoader-c06dccd5.js.map +0 -1
- package/cjs/ToJs-a8d8f3f0.js.map +0 -1
- package/cjs/_commonjsHelpers-b3309d7b.js.map +0 -1
- package/cjs/forms.js +0 -5998
- package/cjs/forms.js.map +0 -1
- package/cjs/reducers-73a03ef4.js +0 -257
- package/cjs/reducers-73a03ef4.js.map +0 -1
- package/cjs/sagas-570f23ba.js +0 -2175
- package/cjs/sagas-570f23ba.js.map +0 -1
- package/cjs/selectors-14caa813.js +0 -228
- package/cjs/selectors-14caa813.js.map +0 -1
- package/cjs/version-34d91f68.js.map +0 -1
- package/esm/App-83107d7e.js.map +0 -1
- package/esm/ChangePassword.container-76fd5e9b.js.map +0 -1
- package/esm/ContensisDeliveryApi-fe57a037.js.map +0 -1
- package/esm/CookieConstants-3d3b6531.js +0 -6
- package/esm/CookieConstants-3d3b6531.js.map +0 -1
- package/esm/RouteLoader-29fd689a.js.map +0 -1
- package/esm/ToJs-df57f31d.js.map +0 -1
- package/esm/_commonjsHelpers-1789f0cf.js.map +0 -1
- package/esm/forms.js +0 -5984
- package/esm/forms.js.map +0 -1
- package/esm/reducers-aa8cef1e.js +0 -234
- package/esm/reducers-aa8cef1e.js.map +0 -1
- package/esm/sagas-07e82e18.js +0 -2083
- package/esm/sagas-07e82e18.js.map +0 -1
- package/esm/selectors-691caf02.js +0 -186
- package/esm/selectors-691caf02.js.map +0 -1
- package/esm/version-3d9911e2.js.map +0 -1
- package/models/forms/index.d.ts +0 -1
- package/models/routing/routes.d.ts +0 -133
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ChangePassword.container-C0tFq0Tf.js","sources":["../src/routing/util/find-contenttype-mapping.ts","../src/user/transformations/mapClientCredentials.ts","../src/user/util/ContensisManagementApi.ts","../src/user/util/OidcUserManager.ts","../src/user/util/LoginHelper.class.ts","../src/user/redux/sagas/login.ts","../src/user/redux/actions.ts","../src/user/hooks/useLogin.ts","../src/user/containers/Login.container.js","../src/user/hooks/useRegistration.js","../src/user/containers/Registration.container.js","../src/user/hooks/useForgotPassword.js","../src/user/containers/ForgotPassword.container.js","../src/user/hooks/useChangePassword.js","../src/user/containers/ChangePassword.container.js"],"sourcesContent":["import { ContentTypeMapping } from '~/models';\n\nexport const findContentTypeMapping = (\n ContentTypeMappings: ContentTypeMapping[],\n contentTypeId: string\n) => ContentTypeMappings.find(ct => ct.contentTypeID === contentTypeId);\n","import { Client } from 'contensis-management-api';\nimport { mapJson } from '~/util/json-mapper';\nimport { ManagementApiClientCredentials } from '../util/ContensisManagementApi';\n\nconst clientCredentials = {\n bearerToken: 'bearerToken',\n bearerTokenExpiryDate: ({ bearerTokenExpiryDate }) =>\n bearerTokenExpiryDate.toISOString(),\n refreshToken: 'refreshToken',\n refreshTokenExpiryDate: ({ refreshTokenExpiryDate }) =>\n refreshTokenExpiryDate.toISOString(),\n contensisClassicToken: 'contensisClassicToken',\n};\nexport default (obj: Client) =>\n mapJson(obj, clientCredentials) as ManagementApiClientCredentials;\n","export type ManagementApiClientCredentials = {\n bearerToken?: string;\n bearerTokenExpiryDate?: Date;\n refreshToken?: string;\n refreshTokenExpiryDate?: Date;\n contensisClassicToken?: string;\n username?: string;\n password?: string;\n};\n\nexport const getManagementApiClient = async ({\n bearerToken,\n bearerTokenExpiryDate,\n refreshToken,\n refreshTokenExpiryDate,\n contensisClassicToken,\n username,\n password,\n}: ManagementApiClientCredentials) => {\n const rootUrl = SERVERS.cms || SERVERS.api; /* global SERVERS */\n const projectId = PROJECTS[0].id; /* global PROJECTS */\n\n let config = {};\n if (refreshToken) {\n config = {\n clientType: 'contensis_classic_refresh_token',\n clientDetails: {\n refreshToken,\n },\n };\n } else {\n config = {\n clientType: 'contensis_classic',\n clientDetails: {\n username,\n password,\n },\n };\n }\n\n let { Client } = await import('contensis-management-api');\n\n if (typeof window === 'undefined') {\n const { UniversalClient } = await import('contensis-management-api');\n Client = UniversalClient;\n }\n\n const client = Client.create({\n ...config,\n projectId,\n rootUrl,\n });\n\n if (bearerToken) client.bearerToken = bearerToken;\n if (bearerTokenExpiryDate)\n client.bearerTokenExpiryDate = bearerTokenExpiryDate;\n if (refreshToken) client.refreshToken = refreshToken;\n if (refreshTokenExpiryDate)\n client.refreshTokenExpiryDate = refreshTokenExpiryDate;\n if (contensisClassicToken)\n (client as any).contensisClassicToken = contensisClassicToken;\n\n return client;\n};\n","import { UserManagerSettings } from 'oidc-client';\n\nconst context = (\n typeof window != 'undefined' ? window : global\n) as typeof globalThis & {\n WSFED_LOGIN: string;\n};\n\nconst requireOidc =\n process.env.NODE_ENV === 'development'\n ? WSFED_LOGIN === 'true' /* global WSFED_LOGIN */\n : context.WSFED_LOGIN === 'true';\n\nconst servers = SERVERS; /* global SERVERS */\n\nexport const userManagerConfig =\n typeof window !== 'undefined'\n ? {\n authority: `${servers.cms}/authenticate/`,\n client_id: 'WebsiteAdfsClient',\n redirect_uri: window.location.toString(),\n post_logout_redirect_uri: window.location.toString(),\n response_type: 'id_token',\n scope: 'openid',\n filterProtocolClaims: false,\n }\n : {};\n\nexport const createUserManager = async (config: UserManagerSettings) => {\n if (typeof window !== 'undefined' && requireOidc) {\n try {\n const { UserManager } = await import(\n /* webpackChunkName: \"oidcclient\" */ 'oidc-client'\n );\n return new UserManager(config);\n } catch (e) {\n console.error('Exception in createUserManager: ', e);\n }\n } else return;\n};\n","import { to } from 'await-to-js';\n\nimport {\n ManagementApiClientCredentials,\n getManagementApiClient,\n} from './ContensisManagementApi';\n\nimport mapClientCredentials from '../transformations/mapClientCredentials';\nimport { createUserManager, userManagerConfig } from './OidcUserManager';\nimport {\n BEARER_TOKEN_COOKIE,\n LOGIN_COOKIE,\n REFRESH_TOKEN_COOKIE,\n} from './CookieConstants';\nimport { AuthenticationState, UserWithGroups } from '../state';\nimport { Client } from 'contensis-management-api';\nimport { CookieHelper } from './CookieHelper.class';\n\nconst context = (\n typeof window != 'undefined' ? window : global\n) as typeof globalThis & {\n WSFED_LOGIN: any;\n};\n\nexport class LoginHelper {\n static CMS_URL = SERVERS.cms /* global SERVERS */;\n static WSFED_LOGIN =\n process.env.NODE_ENV === 'development'\n ? WSFED_LOGIN === 'true' /* global WSFED_LOGIN */\n : context.WSFED_LOGIN === 'true';\n static LOGIN_ROUTE = '/account/login';\n static ACCESS_DENIED_ROUTE = '/account/access-denied';\n\n cookies: CookieHelper;\n\n constructor(cookies?: CookieHelper) {\n this.cookies = cookies || new CookieHelper();\n }\n\n static withCookies = (cookieHelper: CookieHelper) =>\n new LoginHelper(cookieHelper);\n\n static GetUserDetails = async (\n client: Client\n ): Promise<[Error | null, UserWithGroups | undefined]> => {\n const [userError, user] = await to(client.security.users.getCurrent());\n if (user && user.id) {\n const [groupsError, groupsResult] = await to(\n client.security.users.getUserGroups({\n userId: user.id,\n includeInherited: true,\n pageOptions: { pageSize: 100 },\n })\n );\n // Set groups attribute in user object to be the items\n // array from the getUserGroups result\n if (groupsResult && groupsResult.items)\n (user as UserWithGroups).groups = groupsResult.items;\n\n // If groups call fails then log the error but allow the user to login still\n\n if (groupsError) console.log(groupsError);\n }\n return [userError, user as UserWithGroups];\n };\n\n static ClientRedirectToHome(location?: Location) {\n if (typeof window != 'undefined') {\n let url = '/';\n if (location) {\n const { search, hash } = location;\n url = search ? `${url}${search}` : url;\n url = hash ? `${url}${hash}` : url;\n }\n window.location.href = url;\n }\n }\n\n static async ClientRedirectToSignInPage(redirectPath?: string) {\n if (typeof location === 'undefined') return;\n if (LoginHelper.WSFED_LOGIN) {\n await LoginHelper.WsFedLogout();\n await LoginHelper.WsFedLogin();\n } else {\n // Standard Contensis Login\n let url = LoginHelper.LOGIN_ROUTE;\n if (typeof redirectPath === 'string')\n url = `${url}?redirect_uri=${redirectPath}`;\n if (\n typeof location !== 'undefined' &&\n redirectPath !== LoginHelper.LOGIN_ROUTE\n )\n location.replace(url);\n }\n }\n\n static GetAccessDeniedRoute(originalPath) {\n let url = LoginHelper.ACCESS_DENIED_ROUTE;\n if (originalPath !== url && typeof originalPath === 'string')\n url = `${url}?original_uri=${originalPath}`;\n return url;\n }\n\n static ClientRedirectToAccessDeniedPage(originalPath) {\n if (typeof location !== 'undefined')\n location.href = LoginHelper.GetAccessDeniedRoute(originalPath);\n }\n\n static ClientRedirectToPath(redirectPath) {\n if (typeof redirectPath === 'string') {\n if (typeof location !== 'undefined') window.location.href = redirectPath;\n } else LoginHelper.ClientRedirectToHome();\n }\n\n static async WsFedLogin(redirectUri?: string) {\n const userManager = await createUserManager(userManagerConfig);\n userManager?.signinRedirect({\n scope: 'openid',\n response_type: 'id_token',\n redirect_uri: redirectUri || window.location.toString(),\n });\n }\n\n static RemoveSecurityTokenQuery() {\n const params = new URLSearchParams(window.location.search);\n if (params.has('securitytoken') || params.has('securityToken')) {\n params.delete('securitytoken');\n params.delete('securityToken');\n window.location.href = `${window.location.pathname}${\n params.toString() ? `?${params}` : ''\n }`;\n }\n }\n\n static async WsFedLogout(redirectPath?: string) {\n await fetch(\n `${LoginHelper.CMS_URL}/authenticate/logout?jsonResponseRequired=true`,\n {\n credentials: 'include',\n }\n );\n if (redirectPath) {\n window.location.href = redirectPath;\n } else {\n // Explicitly check and remove any stale\n // security token that may be in the query string\n LoginHelper.RemoveSecurityTokenQuery();\n }\n }\n\n static async GetCredentialsForSecurityToken(securityToken: string) {\n const [error, response] = await to(\n fetch(`${LoginHelper.CMS_URL}/REST/Contensis/Security/IsAuthenticated`, {\n method: 'POST',\n headers: {\n Accept: 'application/json',\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify({\n securityToken: encodeURIComponent(securityToken),\n }),\n })\n );\n if (error) return [{ message: 'Failed to fetch credentials' }];\n if (response.ok) {\n const [parseError, body] = await to(response.json());\n if (parseError) return [parseError];\n\n const { LogonResult, ApplicationData = [] } = body;\n if (LogonResult !== 0) {\n console.info(`Security token is invalid - LogonResult: ${LogonResult}`);\n return [\n { message: 'Security token is invalid', data: ApplicationData },\n ];\n }\n if (ApplicationData.length > 0) {\n let refreshToken;\n ApplicationData.forEach(item => {\n if (item.Key === 'ContensisSecurityRefreshToken')\n refreshToken = item.Value;\n });\n if (!refreshToken) {\n return [\n {\n message:\n 'Fetch credentials: Unable to find ContensisSecurityRefreshToken',\n },\n ];\n }\n return [undefined, refreshToken];\n } else {\n return [\n {\n message:\n 'Fetch credentials: Unable to find ContensisSecurityRefreshToken',\n },\n ];\n }\n } else {\n return [\n {\n message: `Fetch credentials error: ${response.status} ${response.statusText}`,\n },\n ];\n }\n }\n\n // static isZengentiStaff(email) {\n // const emailRefs = ['@zengenti', '@contensis'];\n\n // return emailRefs.some(emailRef => {\n // if (email.includes(emailRef)) {\n // return true;\n // }\n // });\n // }\n\n SetLoginCookies({\n bearerToken,\n contensisClassicToken,\n refreshToken,\n }: ManagementApiClientCredentials) {\n if (bearerToken) this.cookies.SetCookie(BEARER_TOKEN_COOKIE, bearerToken);\n\n if (contensisClassicToken)\n this.cookies.SetCookie(LOGIN_COOKIE, contensisClassicToken);\n\n if (refreshToken)\n this.cookies.SetCookie(REFRESH_TOKEN_COOKIE, refreshToken);\n }\n\n GetCachedCredentials() {\n return {\n bearerToken: null,\n bearerTokenExpiryDate: null,\n refreshToken: this.cookies.GetCookie(REFRESH_TOKEN_COOKIE),\n refreshTokenExpiryDate: null,\n contensisClassicToken: this.cookies.GetCookie(LOGIN_COOKIE),\n securityToken: null,\n };\n }\n\n ClearCachedCredentials() {\n this.cookies.DeleteCookie(LOGIN_COOKIE);\n this.cookies.DeleteCookie(REFRESH_TOKEN_COOKIE);\n this.cookies.DeleteCookie(BEARER_TOKEN_COOKIE); // additional cookie used by @contensis/forms package\n\n if (LoginHelper.WSFED_LOGIN && typeof window !== 'undefined') {\n // remove any oidc keys left over in localStorage\n const { localStorage } = window;\n const keys: string[] = [];\n for (let i = 0; i < localStorage.length; i++) {\n const key = localStorage.key(i);\n if (typeof key === 'string' && key.startsWith('oidc.')) keys.push(key);\n }\n keys.forEach(key => localStorage.removeItem(key));\n }\n }\n\n async LoginUser({\n username,\n password,\n clientCredentials,\n }: {\n username?: string;\n password?: string;\n clientCredentials?: ManagementApiClientCredentials;\n }) {\n let credentials = clientCredentials;\n let authenticationState: AuthenticationState = {\n clientCredentials: null,\n isAuthenticated: false,\n isAuthenticationError: false,\n isError: false,\n };\n let transientClient: Client | null = null;\n let user;\n\n if (username && password) {\n // Get a management client with username and password\n transientClient = await getManagementApiClient({\n username,\n password,\n });\n\n // Ensure the client has requested a bearer token\n const [loginError, clientBearerToken] = await to(\n transientClient.ensureBearerToken()\n );\n\n // Problem getting token with username and password\n if (loginError) {\n authenticationState = {\n clientCredentials: null,\n errorMessage: loginError.message || null,\n isAuthenticated: false,\n isAuthenticationError: loginError.name.includes(\n 'ContensisAuthenticationError'\n ),\n isError: true,\n };\n this.ClearCachedCredentials();\n }\n\n // Got a token using username and password\n if (clientBearerToken) {\n // Set credentials so we can continue to GetUserDetails\n const clientCredentials = mapClientCredentials(transientClient);\n this.SetLoginCookies(clientCredentials);\n authenticationState = {\n clientCredentials,\n isAuthenticated: true,\n isAuthenticationError: false,\n isError: false,\n };\n credentials = clientCredentials;\n }\n }\n\n // If we have credentials supplied by a successful username and password login\n // or clientCredentials supplied in the options argument we can continue to\n // fetch the user's details\n if (credentials) {\n const client =\n transientClient || (await getManagementApiClient(credentials));\n const [error, userDetails] = await LoginHelper.GetUserDetails(client);\n\n if (error) {\n authenticationState = {\n clientCredentials: null,\n errorMessage: error.message,\n isAuthenticated: false,\n isAuthenticationError: false,\n isError: true,\n };\n this.ClearCachedCredentials();\n } else {\n // Ensure we get latest refreshToken and contensisClassicToken from the latest client\n const latestCredentials = mapClientCredentials(client);\n this.SetLoginCookies(latestCredentials);\n\n user = userDetails;\n authenticationState = {\n clientCredentials: latestCredentials,\n isAuthenticated: true,\n isAuthenticationError: false,\n isError: false,\n };\n }\n }\n\n return { authenticationState, user };\n }\n\n LogoutUser(redirectPath?: string) {\n this.ClearCachedCredentials();\n if (LoginHelper.WSFED_LOGIN) {\n LoginHelper.WsFedLogout(redirectPath);\n } else {\n if (redirectPath) LoginHelper.ClientRedirectToPath(redirectPath);\n else LoginHelper.ClientRedirectToSignInPage();\n }\n }\n}\n","import { takeEvery, select, put, call } from 'redux-saga/effects';\nimport {\n SET_AUTHENTICATION_STATE,\n LOGIN_USER,\n LOGOUT_USER,\n VALIDATE_USER,\n} from '../types';\nimport {\n selectUserIsAuthenticated,\n selectClientCredentials,\n selectUserGroups,\n} from '../selectors';\n\nimport { setRoute } from '~/routing/redux/actions';\nimport { selectCurrentSearch } from '~/routing/redux/selectors';\nimport { findContentTypeMapping } from '~/routing/util/find-contenttype-mapping';\n\nimport mapClientCredentials from '~/user/transformations/mapClientCredentials';\n\nimport { getManagementApiClient } from '~/user/util/ContensisManagementApi';\nimport { LoginHelper } from '~/user/util/LoginHelper.class';\nimport { matchUserGroup } from '~/user/util/matchGroups';\nimport { queryParams } from '~/util/navigation';\n\nexport const loginSagas = [\n takeEvery(LOGIN_USER, loginUserSaga),\n takeEvery(LOGOUT_USER, logoutUserSaga),\n takeEvery(VALIDATE_USER, validateUserSaga),\n takeEvery(SET_AUTHENTICATION_STATE, redirectAfterSuccessfulLoginSaga),\n];\n\nexport function* handleRequiresLoginSaga(action: any) {\n const {\n cookies,\n entry,\n path,\n requireLogin,\n routes: { ContentTypeMappings },\n staticRoute,\n } = action;\n let userLoggedIn = yield select(selectUserIsAuthenticated);\n\n // Check for a securityToken in querystring\n const currentQs = queryParams(yield select(selectCurrentSearch));\n const securityToken = currentQs.securityToken || currentQs.securitytoken;\n\n // Check if any of the defined routes have \"requireLogin\" attribute\n const { requireLogin: authRoute } = (staticRoute && staticRoute.route) || {};\n const { requireLogin: authContentType } =\n (entry &&\n findContentTypeMapping(ContentTypeMappings, entry?.sys?.contentTypeId)) ||\n {};\n\n // If requireLogin, authRoute or authContentType has been specified as an\n // array of groups we can merge all the arrays and match on any group supplied\n const routeRequiresGroups = [\n ...((Array.isArray(authContentType) && authContentType) || []),\n ...((Array.isArray(authRoute) && authRoute) || []),\n ...((Array.isArray(requireLogin) && requireLogin) || []),\n ];\n const routeRequiresLogin = !!authContentType || !!authRoute || !!requireLogin;\n\n if (!userLoggedIn) {\n // If cookies or securityToken are found on any route change\n // always validate and login the user\n if (routeRequiresLogin) {\n console.info(`Route requires login: ${path}`);\n // If routeRequiresLogin do a blocking call that returns userLoggedIn\n userLoggedIn = yield call(validateUserSaga, {\n cookies,\n securityToken,\n });\n console.info(`User logged in: ${userLoggedIn}`);\n }\n // otherwise do a non blocking put to handle validation in the background\n else yield put({ type: VALIDATE_USER, cookies, securityToken });\n }\n\n if (routeRequiresLogin) {\n // If a security token is in the querystring and we are not already\n // logged in something is wrong and we won't bother going on another redirect loop\n if (!userLoggedIn && !securityToken) {\n LoginHelper.ClientRedirectToSignInPage(action.location.pathname);\n } else if (routeRequiresGroups.length > 0) {\n const userGroups = yield select(selectUserGroups, 'js');\n const groupMatch = matchUserGroup(userGroups, routeRequiresGroups);\n\n if (!groupMatch)\n LoginHelper.ClientRedirectToAccessDeniedPage(action.location.pathname);\n }\n }\n\n return userLoggedIn;\n}\n\nfunction* validateUserSaga({ cookies, securityToken }: any) {\n const login = LoginHelper.withCookies(cookies);\n // Check for refreshToken in cookies\n let clientCredentials = login.GetCachedCredentials();\n\n if (\n securityToken ||\n clientCredentials.securityToken ||\n clientCredentials.refreshToken\n ) {\n // We only attempt to validate the user if one of the stored\n // tokens are found, in this case we set loading state manually\n // so we don't need to set and unset loading if there are no stored\n yield put({\n type: SET_AUTHENTICATION_STATE,\n authenticationState: {\n isLoading: true,\n },\n });\n // If we have just a security token we will call a CMS endpoint\n // and provide us with a RefreshToken cookie we can use during login\n if (\n securityToken ||\n (clientCredentials.securityToken && !clientCredentials.refreshToken)\n ) {\n const [error, refreshToken] =\n yield LoginHelper.GetCredentialsForSecurityToken(\n securityToken || clientCredentials.securityToken\n );\n if (refreshToken) {\n // Set cookies and reload values\n login.SetLoginCookies({\n contensisClassicToken: securityToken,\n refreshToken,\n });\n clientCredentials = login.GetCachedCredentials();\n }\n if (error) {\n login.ClearCachedCredentials();\n yield put({\n type: SET_AUTHENTICATION_STATE,\n authenticationState: {\n isError: true,\n errorMessage:\n error?.message ||\n (error && 'toString' in error && error.toString()),\n },\n });\n }\n }\n\n // Log the user in if a refreshToken is found\n if (clientCredentials.refreshToken) {\n console.info(\n `Login user with refreshToken ${clientCredentials.refreshToken}`\n );\n yield call(loginUserSaga, {\n clientCredentials,\n cookies: login.cookies,\n });\n }\n }\n\n // Tell any callers have we successfully logged in?\n return yield select(selectUserIsAuthenticated);\n}\n\nfunction* loginUserSaga(action: any = {}) {\n const { username, password, clientCredentials, cookies } = action;\n const login = LoginHelper.withCookies(cookies);\n\n // If a WSFED_LOGIN site has dispatched the loginUser action\n // just redirect them to the Identity Provider sign in\n if (action.type === LOGIN_USER && LoginHelper.WSFED_LOGIN)\n LoginHelper.ClientRedirectToSignInPage();\n\n const { authenticationState, user } = yield login.LoginUser({\n username,\n password,\n clientCredentials,\n });\n\n yield put({\n type: SET_AUTHENTICATION_STATE,\n authenticationState,\n user,\n });\n}\n\nconst removeHostnamePart = path => {\n // eslint-disable-next-line no-console\n console.log(path);\n const relativePath = '/' + path.split('/').splice(3).join('/');\n // eslint-disable-next-line no-console\n console.log(relativePath);\n return relativePath;\n};\n\nfunction* redirectAfterSuccessfulLoginSaga() {\n const isLoggedIn = yield select(selectUserIsAuthenticated);\n const { redirect_uri: redirectPath, ReturnURL: assetRedirectPath } =\n queryParams(yield select(selectCurrentSearch));\n\n if (isLoggedIn && assetRedirectPath && typeof window != 'undefined') {\n const path = removeHostnamePart(assetRedirectPath);\n // This has to be a hard href to get the app to\n // leave React and hit the server for the IIS hosted assets\n window.location.href = path;\n // yield put(setRoute(path)); // does not work in this scenario\n } else if (isLoggedIn && redirectPath) {\n yield put(setRoute(redirectPath));\n }\n}\n\nfunction* logoutUserSaga({ redirectPath, cookies }: any) {\n yield put({\n type: SET_AUTHENTICATION_STATE,\n user: null,\n });\n yield LoginHelper.withCookies(cookies).LogoutUser(redirectPath);\n}\n\nexport function* refreshSecurityToken() {\n const clientCredentials = yield select(selectClientCredentials, 'js');\n if (Object.keys(clientCredentials).length > 0) {\n const client = yield getManagementApiClient(clientCredentials);\n yield client.authenticate();\n\n yield put({\n type: SET_AUTHENTICATION_STATE,\n authenticationState: {\n clientCredentials: mapClientCredentials(client),\n },\n });\n }\n}\n","import { action } from '~/redux/util';\nimport {\n CHANGE_USER_PASSWORD,\n LOGIN_USER,\n LOGOUT_USER,\n REGISTER_USER,\n REQUEST_USER_PASSWORD_RESET,\n RESET_USER_PASSWORD,\n} from './types';\nimport { CookieHelper } from '../util/CookieHelper.class';\n\nexport const loginUser = (\n username: string,\n password: string,\n cookies?: CookieHelper\n) => action(LOGIN_USER, { username, password, cookies });\n\nexport const logoutUser = (redirectPath?: string, cookies?: CookieHelper) =>\n action(LOGOUT_USER, { redirectPath, cookies });\n\nexport const registerUser = (user, mappers) =>\n action(REGISTER_USER, {\n user,\n mappers,\n });\n\nexport const requestPasswordReset = userEmailObject =>\n action(REQUEST_USER_PASSWORD_RESET, { userEmailObject });\n\nexport const resetPassword = resetPasswordObject =>\n action(RESET_USER_PASSWORD, { resetPasswordObject });\n\nexport const changePassword = (userId, currentPassword, newPassword) =>\n action(CHANGE_USER_PASSWORD, { userId, currentPassword, newPassword });\n","import { useCookies } from 'react-cookie';\nimport { useDispatch, useSelector } from 'react-redux';\nimport { loginUser, logoutUser } from '../redux/actions';\nimport {\n selectUser,\n selectUserIsAuthenticationError,\n selectUserIsError,\n selectUserErrorMessage,\n selectUserIsAuthenticated,\n selectUserIsLoading,\n} from '../redux/selectors';\nimport { CookieHelper } from '../util/CookieHelper.class';\n\nconst useLogin = () => {\n const cookies = new CookieHelper(...useCookies());\n\n const dispatch = useDispatch();\n const select = useSelector;\n\n return {\n loginUser: (username: string, password: string) =>\n dispatch(loginUser(username, password, cookies)),\n logoutUser: (redirectPath?: string) =>\n dispatch(logoutUser(redirectPath, cookies)),\n errorMessage: select(selectUserErrorMessage),\n isAuthenticated: select(selectUserIsAuthenticated),\n isAuthenticationError: select(selectUserIsAuthenticationError),\n isError: select(selectUserIsError),\n isLoading: select(selectUserIsLoading),\n user: select(selectUser),\n // DEPRECATED: authenticationError is deprecated use isAuthenticationError instead\n authenticationError: select(selectUserIsAuthenticationError),\n // DEPRECATED: authenticationErrorMessage is deprecated use errorMessage instead\n authenticationErrorMessage: select(selectUserErrorMessage),\n // DEPRECATED: error is deprecated use isError instead\n error: select(selectUserIsError),\n };\n};\n\nexport default useLogin;\n","import useLogin from '../hooks/useLogin';\nimport { toJS } from '~/util/ToJs';\n\nconst LoginContainer = ({ children, ...props }) => {\n const userProps = useLogin(props);\n return children(userProps);\n};\n\nLoginContainer.propTypes = {};\n\nexport default toJS(LoginContainer);\n","import { useDispatch, useSelector } from 'react-redux';\nimport { registerUser } from '../redux/actions';\nimport {\n selectUserRegistration,\n selectUserRegistrationError,\n selectUserRegistrationIsLoading,\n selectUserRegistrationIsSuccess,\n} from '../redux/selectors';\n\nconst useRegistration = () => {\n const dispatch = useDispatch();\n const select = useSelector;\n\n return {\n registerUser: (user, mappers) => dispatch(registerUser(user, mappers)),\n error: select(selectUserRegistrationError),\n isLoading: select(selectUserRegistrationIsLoading),\n isSuccess: select(selectUserRegistrationIsSuccess),\n user: select(selectUserRegistration),\n };\n};\n\nexport default useRegistration;\n","import useRegistration from '../hooks/useRegistration';\nimport { toJS } from '~/util/ToJs';\n\nconst RegistrationContainer = ({ children, ...props }) => {\n const userProps = useRegistration(props);\n return children(userProps);\n};\n\nRegistrationContainer.propTypes = {};\n\nexport default toJS(RegistrationContainer);\n","import { useDispatch, useSelector } from 'react-redux';\nimport { requestPasswordReset, resetPassword } from '../redux/actions';\nimport {\n selectPasswordResetRequestError,\n selectPasswordResetRequestSending,\n selectPasswordResetRequestSent,\n selectResetPasswordSending,\n selectResetPasswordSent,\n selectResetPasswordError,\n} from '../redux/selectors';\nimport { selectCurrentSearch } from '~/routing/redux/selectors';\n\nconst useForgotPassword = () => {\n const dispatch = useDispatch();\n const select = useSelector;\n\n return {\n isLoading: select(selectPasswordResetRequestSending),\n isSuccess: select(selectPasswordResetRequestSent),\n error: select(selectPasswordResetRequestError),\n requestPasswordReset: userEmailObject =>\n dispatch(requestPasswordReset(userEmailObject)),\n\n setNewPassword: {\n queryString: select(selectCurrentSearch),\n isLoading: select(selectResetPasswordSending),\n isSuccess: select(selectResetPasswordSent),\n error: select(selectResetPasswordError),\n submit: resetPasswordObject =>\n dispatch(resetPassword(resetPasswordObject)),\n },\n };\n};\n\nexport default useForgotPassword;\n","import useForgotPassword from '../hooks/useForgotPassword';\nimport { toJS } from '~/util/ToJs';\n\nconst ForgotPasswordContainer = ({ children, ...props }) => {\n const userProps = useForgotPassword(props);\n return children(userProps);\n};\n\nForgotPasswordContainer.propTypes = {};\n\nexport default toJS(ForgotPasswordContainer);\n","import { useDispatch, useSelector } from 'react-redux';\nimport { changePassword } from '../redux/actions';\nimport {\n selectChangePasswordSending,\n selectChangePasswordSent,\n selectChangePasswordError,\n selectUserIsAuthenticated,\n selectUserGuid,\n} from '../redux/selectors';\n\nconst useChangePassword = () => {\n const dispatch = useDispatch();\n const select = useSelector;\n\n return {\n isLoading: select(selectChangePasswordSending),\n isSuccess: select(selectChangePasswordSent),\n userId: select(selectUserGuid),\n isLoggedIn: select(selectUserIsAuthenticated),\n error: select(selectChangePasswordError),\n changePassword: (userId, currentPassword, newPassword) =>\n dispatch(changePassword(userId, currentPassword, newPassword)),\n };\n};\n\nexport default useChangePassword;\n","import useChangePassword from '../hooks/useChangePassword';\nimport { toJS } from '~/util/ToJs';\n\nconst ChangePasswordContainer = ({ children, ...props }) => {\n const userProps = useChangePassword(props);\n return children(userProps);\n};\n\nChangePasswordContainer.propTypes = {};\n\nexport default toJS(ChangePasswordContainer);\n"],"names":["findContentTypeMapping","ContentTypeMappings","contentTypeId","find","ct","contentTypeID","clientCredentials","bearerToken","bearerTokenExpiryDate","toISOString","refreshToken","refreshTokenExpiryDate","contensisClassicToken","obj","mapJson","getManagementApiClient","username","password","rootUrl","SERVERS","cms","api","projectId","PROJECTS","id","config","clientType","clientDetails","Client","window","UniversalClient","client","create","context","global","requireOidc","process","env","NODE_ENV","WSFED_LOGIN","servers","userManagerConfig","authority","client_id","redirect_uri","location","toString","post_logout_redirect_uri","response_type","scope","filterProtocolClaims","createUserManager","UserManager","e","console","error","LoginHelper","constructor","cookies","CookieHelper","ClientRedirectToHome","url","search","hash","href","ClientRedirectToSignInPage","redirectPath","WsFedLogout","WsFedLogin","LOGIN_ROUTE","replace","GetAccessDeniedRoute","originalPath","ACCESS_DENIED_ROUTE","ClientRedirectToAccessDeniedPage","ClientRedirectToPath","redirectUri","userManager","signinRedirect","RemoveSecurityTokenQuery","params","URLSearchParams","has","delete","pathname","fetch","CMS_URL","credentials","GetCredentialsForSecurityToken","securityToken","response","to","method","headers","Accept","body","JSON","stringify","encodeURIComponent","message","ok","parseError","json","LogonResult","ApplicationData","info","data","length","forEach","item","Key","Value","undefined","status","statusText","SetLoginCookies","SetCookie","BEARER_TOKEN_COOKIE","LOGIN_COOKIE","REFRESH_TOKEN_COOKIE","GetCachedCredentials","GetCookie","ClearCachedCredentials","DeleteCookie","localStorage","keys","i","key","startsWith","push","removeItem","LoginUser","authenticationState","isAuthenticated","isAuthenticationError","isError","transientClient","user","loginError","clientBearerToken","ensureBearerToken","errorMessage","name","includes","mapClientCredentials","userDetails","GetUserDetails","latestCredentials","LogoutUser","_LoginHelper","withCookies","cookieHelper","userError","security","users","getCurrent","groupsError","groupsResult","getUserGroups","userId","includeInherited","pageOptions","pageSize","items","groups","log","loginSagas","takeEvery","LOGIN_USER","loginUserSaga","LOGOUT_USER","logoutUserSaga","VALIDATE_USER","validateUserSaga","SET_AUTHENTICATION_STATE","redirectAfterSuccessfulLoginSaga","handleRequiresLoginSaga","action","_entry$sys","entry","path","requireLogin","routes","staticRoute","userLoggedIn","select","selectUserIsAuthenticated","currentQs","queryParams","selectCurrentSearch","securitytoken","authRoute","route","authContentType","sys","routeRequiresGroups","Array","isArray","routeRequiresLogin","call","put","type","userGroups","selectUserGroups","groupMatch","matchUserGroup","login","isLoading","removeHostnamePart","relativePath","split","splice","join","isLoggedIn","ReturnURL","assetRedirectPath","setRoute","refreshSecurityToken","selectClientCredentials","Object","authenticate","loginUser","logoutUser","registerUser","mappers","REGISTER_USER","requestPasswordReset","userEmailObject","REQUEST_USER_PASSWORD_RESET","resetPassword","resetPasswordObject","RESET_USER_PASSWORD","changePassword","currentPassword","newPassword","CHANGE_USER_PASSWORD","useLogin","useCookies","dispatch","useDispatch","useSelector","selectUserErrorMessage","selectUserIsAuthenticationError","selectUserIsError","selectUserIsLoading","selectUser","authenticationError","authenticationErrorMessage","LoginContainer","children","props","userProps","propTypes","toJS","useRegistration","selectUserRegistrationError","selectUserRegistrationIsLoading","isSuccess","selectUserRegistrationIsSuccess","selectUserRegistration","RegistrationContainer","useForgotPassword","selectPasswordResetRequestSending","selectPasswordResetRequestSent","selectPasswordResetRequestError","setNewPassword","queryString","selectResetPasswordSending","selectResetPasswordSent","selectResetPasswordError","submit","ForgotPasswordContainer","useChangePassword","selectChangePasswordSending","selectChangePasswordSent","selectUserGuid","selectChangePasswordError","ChangePasswordContainer"],"mappings":"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"}
|
|
@@ -0,0 +1,464 @@
|
|
|
1
|
+
const BEARER_TOKEN_COOKIE = 'ContensisSecurityBearerToken';
|
|
2
|
+
const LOGIN_COOKIE = 'ContensisCMSUserName';
|
|
3
|
+
const REFRESH_TOKEN_COOKIE = 'RefreshToken';
|
|
4
|
+
const findLoginCookies = cookies => typeof cookies === 'object' ? Object.fromEntries(Object.entries(cookies).filter(([name]) => [LOGIN_COOKIE, REFRESH_TOKEN_COOKIE].includes(name))) : cookies;
|
|
5
|
+
|
|
6
|
+
var dist = {};
|
|
7
|
+
|
|
8
|
+
var hasRequiredDist;
|
|
9
|
+
|
|
10
|
+
function requireDist () {
|
|
11
|
+
if (hasRequiredDist) return dist;
|
|
12
|
+
hasRequiredDist = 1;
|
|
13
|
+
Object.defineProperty(dist, "__esModule", { value: true });
|
|
14
|
+
dist.parse = parse;
|
|
15
|
+
dist.serialize = serialize;
|
|
16
|
+
/**
|
|
17
|
+
* RegExp to match cookie-name in RFC 6265 sec 4.1.1
|
|
18
|
+
* This refers out to the obsoleted definition of token in RFC 2616 sec 2.2
|
|
19
|
+
* which has been replaced by the token definition in RFC 7230 appendix B.
|
|
20
|
+
*
|
|
21
|
+
* cookie-name = token
|
|
22
|
+
* token = 1*tchar
|
|
23
|
+
* tchar = "!" / "#" / "$" / "%" / "&" / "'" /
|
|
24
|
+
* "*" / "+" / "-" / "." / "^" / "_" /
|
|
25
|
+
* "`" / "|" / "~" / DIGIT / ALPHA
|
|
26
|
+
*
|
|
27
|
+
* Note: Allowing more characters - https://github.com/jshttp/cookie/issues/191
|
|
28
|
+
* Allow same range as cookie value, except `=`, which delimits end of name.
|
|
29
|
+
*/
|
|
30
|
+
const cookieNameRegExp = /^[\u0021-\u003A\u003C\u003E-\u007E]+$/;
|
|
31
|
+
/**
|
|
32
|
+
* RegExp to match cookie-value in RFC 6265 sec 4.1.1
|
|
33
|
+
*
|
|
34
|
+
* cookie-value = *cookie-octet / ( DQUOTE *cookie-octet DQUOTE )
|
|
35
|
+
* cookie-octet = %x21 / %x23-2B / %x2D-3A / %x3C-5B / %x5D-7E
|
|
36
|
+
* ; US-ASCII characters excluding CTLs,
|
|
37
|
+
* ; whitespace DQUOTE, comma, semicolon,
|
|
38
|
+
* ; and backslash
|
|
39
|
+
*
|
|
40
|
+
* Allowing more characters: https://github.com/jshttp/cookie/issues/191
|
|
41
|
+
* Comma, backslash, and DQUOTE are not part of the parsing algorithm.
|
|
42
|
+
*/
|
|
43
|
+
const cookieValueRegExp = /^[\u0021-\u003A\u003C-\u007E]*$/;
|
|
44
|
+
/**
|
|
45
|
+
* RegExp to match domain-value in RFC 6265 sec 4.1.1
|
|
46
|
+
*
|
|
47
|
+
* domain-value = <subdomain>
|
|
48
|
+
* ; defined in [RFC1034], Section 3.5, as
|
|
49
|
+
* ; enhanced by [RFC1123], Section 2.1
|
|
50
|
+
* <subdomain> = <label> | <subdomain> "." <label>
|
|
51
|
+
* <label> = <let-dig> [ [ <ldh-str> ] <let-dig> ]
|
|
52
|
+
* Labels must be 63 characters or less.
|
|
53
|
+
* 'let-dig' not 'letter' in the first char, per RFC1123
|
|
54
|
+
* <ldh-str> = <let-dig-hyp> | <let-dig-hyp> <ldh-str>
|
|
55
|
+
* <let-dig-hyp> = <let-dig> | "-"
|
|
56
|
+
* <let-dig> = <letter> | <digit>
|
|
57
|
+
* <letter> = any one of the 52 alphabetic characters A through Z in
|
|
58
|
+
* upper case and a through z in lower case
|
|
59
|
+
* <digit> = any one of the ten digits 0 through 9
|
|
60
|
+
*
|
|
61
|
+
* Keep support for leading dot: https://github.com/jshttp/cookie/issues/173
|
|
62
|
+
*
|
|
63
|
+
* > (Note that a leading %x2E ("."), if present, is ignored even though that
|
|
64
|
+
* character is not permitted, but a trailing %x2E ("."), if present, will
|
|
65
|
+
* cause the user agent to ignore the attribute.)
|
|
66
|
+
*/
|
|
67
|
+
const domainValueRegExp = /^([.]?[a-z0-9]([a-z0-9-]{0,61}[a-z0-9])?)([.][a-z0-9]([a-z0-9-]{0,61}[a-z0-9])?)*$/i;
|
|
68
|
+
/**
|
|
69
|
+
* RegExp to match path-value in RFC 6265 sec 4.1.1
|
|
70
|
+
*
|
|
71
|
+
* path-value = <any CHAR except CTLs or ";">
|
|
72
|
+
* CHAR = %x01-7F
|
|
73
|
+
* ; defined in RFC 5234 appendix B.1
|
|
74
|
+
*/
|
|
75
|
+
const pathValueRegExp = /^[\u0020-\u003A\u003D-\u007E]*$/;
|
|
76
|
+
const __toString = Object.prototype.toString;
|
|
77
|
+
const NullObject = /* @__PURE__ */ (() => {
|
|
78
|
+
const C = function () { };
|
|
79
|
+
C.prototype = Object.create(null);
|
|
80
|
+
return C;
|
|
81
|
+
})();
|
|
82
|
+
/**
|
|
83
|
+
* Parse a cookie header.
|
|
84
|
+
*
|
|
85
|
+
* Parse the given cookie header string into an object
|
|
86
|
+
* The object has the various cookies as keys(names) => values
|
|
87
|
+
*/
|
|
88
|
+
function parse(str, options) {
|
|
89
|
+
const obj = new NullObject();
|
|
90
|
+
const len = str.length;
|
|
91
|
+
// RFC 6265 sec 4.1.1, RFC 2616 2.2 defines a cookie name consists of one char minimum, plus '='.
|
|
92
|
+
if (len < 2)
|
|
93
|
+
return obj;
|
|
94
|
+
const dec = options?.decode || decode;
|
|
95
|
+
let index = 0;
|
|
96
|
+
do {
|
|
97
|
+
const eqIdx = str.indexOf("=", index);
|
|
98
|
+
if (eqIdx === -1)
|
|
99
|
+
break; // No more cookie pairs.
|
|
100
|
+
const colonIdx = str.indexOf(";", index);
|
|
101
|
+
const endIdx = colonIdx === -1 ? len : colonIdx;
|
|
102
|
+
if (eqIdx > endIdx) {
|
|
103
|
+
// backtrack on prior semicolon
|
|
104
|
+
index = str.lastIndexOf(";", eqIdx - 1) + 1;
|
|
105
|
+
continue;
|
|
106
|
+
}
|
|
107
|
+
const keyStartIdx = startIndex(str, index, eqIdx);
|
|
108
|
+
const keyEndIdx = endIndex(str, eqIdx, keyStartIdx);
|
|
109
|
+
const key = str.slice(keyStartIdx, keyEndIdx);
|
|
110
|
+
// only assign once
|
|
111
|
+
if (obj[key] === undefined) {
|
|
112
|
+
let valStartIdx = startIndex(str, eqIdx + 1, endIdx);
|
|
113
|
+
let valEndIdx = endIndex(str, endIdx, valStartIdx);
|
|
114
|
+
const value = dec(str.slice(valStartIdx, valEndIdx));
|
|
115
|
+
obj[key] = value;
|
|
116
|
+
}
|
|
117
|
+
index = endIdx + 1;
|
|
118
|
+
} while (index < len);
|
|
119
|
+
return obj;
|
|
120
|
+
}
|
|
121
|
+
function startIndex(str, index, max) {
|
|
122
|
+
do {
|
|
123
|
+
const code = str.charCodeAt(index);
|
|
124
|
+
if (code !== 0x20 /* */ && code !== 0x09 /* \t */)
|
|
125
|
+
return index;
|
|
126
|
+
} while (++index < max);
|
|
127
|
+
return max;
|
|
128
|
+
}
|
|
129
|
+
function endIndex(str, index, min) {
|
|
130
|
+
while (index > min) {
|
|
131
|
+
const code = str.charCodeAt(--index);
|
|
132
|
+
if (code !== 0x20 /* */ && code !== 0x09 /* \t */)
|
|
133
|
+
return index + 1;
|
|
134
|
+
}
|
|
135
|
+
return min;
|
|
136
|
+
}
|
|
137
|
+
/**
|
|
138
|
+
* Serialize data into a cookie header.
|
|
139
|
+
*
|
|
140
|
+
* Serialize a name value pair into a cookie string suitable for
|
|
141
|
+
* http headers. An optional options object specifies cookie parameters.
|
|
142
|
+
*
|
|
143
|
+
* serialize('foo', 'bar', { httpOnly: true })
|
|
144
|
+
* => "foo=bar; httpOnly"
|
|
145
|
+
*/
|
|
146
|
+
function serialize(name, val, options) {
|
|
147
|
+
const enc = options?.encode || encodeURIComponent;
|
|
148
|
+
if (!cookieNameRegExp.test(name)) {
|
|
149
|
+
throw new TypeError(`argument name is invalid: ${name}`);
|
|
150
|
+
}
|
|
151
|
+
const value = enc(val);
|
|
152
|
+
if (!cookieValueRegExp.test(value)) {
|
|
153
|
+
throw new TypeError(`argument val is invalid: ${val}`);
|
|
154
|
+
}
|
|
155
|
+
let str = name + "=" + value;
|
|
156
|
+
if (!options)
|
|
157
|
+
return str;
|
|
158
|
+
if (options.maxAge !== undefined) {
|
|
159
|
+
if (!Number.isInteger(options.maxAge)) {
|
|
160
|
+
throw new TypeError(`option maxAge is invalid: ${options.maxAge}`);
|
|
161
|
+
}
|
|
162
|
+
str += "; Max-Age=" + options.maxAge;
|
|
163
|
+
}
|
|
164
|
+
if (options.domain) {
|
|
165
|
+
if (!domainValueRegExp.test(options.domain)) {
|
|
166
|
+
throw new TypeError(`option domain is invalid: ${options.domain}`);
|
|
167
|
+
}
|
|
168
|
+
str += "; Domain=" + options.domain;
|
|
169
|
+
}
|
|
170
|
+
if (options.path) {
|
|
171
|
+
if (!pathValueRegExp.test(options.path)) {
|
|
172
|
+
throw new TypeError(`option path is invalid: ${options.path}`);
|
|
173
|
+
}
|
|
174
|
+
str += "; Path=" + options.path;
|
|
175
|
+
}
|
|
176
|
+
if (options.expires) {
|
|
177
|
+
if (!isDate(options.expires) ||
|
|
178
|
+
!Number.isFinite(options.expires.valueOf())) {
|
|
179
|
+
throw new TypeError(`option expires is invalid: ${options.expires}`);
|
|
180
|
+
}
|
|
181
|
+
str += "; Expires=" + options.expires.toUTCString();
|
|
182
|
+
}
|
|
183
|
+
if (options.httpOnly) {
|
|
184
|
+
str += "; HttpOnly";
|
|
185
|
+
}
|
|
186
|
+
if (options.secure) {
|
|
187
|
+
str += "; Secure";
|
|
188
|
+
}
|
|
189
|
+
if (options.partitioned) {
|
|
190
|
+
str += "; Partitioned";
|
|
191
|
+
}
|
|
192
|
+
if (options.priority) {
|
|
193
|
+
const priority = typeof options.priority === "string"
|
|
194
|
+
? options.priority.toLowerCase()
|
|
195
|
+
: undefined;
|
|
196
|
+
switch (priority) {
|
|
197
|
+
case "low":
|
|
198
|
+
str += "; Priority=Low";
|
|
199
|
+
break;
|
|
200
|
+
case "medium":
|
|
201
|
+
str += "; Priority=Medium";
|
|
202
|
+
break;
|
|
203
|
+
case "high":
|
|
204
|
+
str += "; Priority=High";
|
|
205
|
+
break;
|
|
206
|
+
default:
|
|
207
|
+
throw new TypeError(`option priority is invalid: ${options.priority}`);
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
if (options.sameSite) {
|
|
211
|
+
const sameSite = typeof options.sameSite === "string"
|
|
212
|
+
? options.sameSite.toLowerCase()
|
|
213
|
+
: options.sameSite;
|
|
214
|
+
switch (sameSite) {
|
|
215
|
+
case true:
|
|
216
|
+
case "strict":
|
|
217
|
+
str += "; SameSite=Strict";
|
|
218
|
+
break;
|
|
219
|
+
case "lax":
|
|
220
|
+
str += "; SameSite=Lax";
|
|
221
|
+
break;
|
|
222
|
+
case "none":
|
|
223
|
+
str += "; SameSite=None";
|
|
224
|
+
break;
|
|
225
|
+
default:
|
|
226
|
+
throw new TypeError(`option sameSite is invalid: ${options.sameSite}`);
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
return str;
|
|
230
|
+
}
|
|
231
|
+
/**
|
|
232
|
+
* URL-decode string value. Optimized to skip native call when no %.
|
|
233
|
+
*/
|
|
234
|
+
function decode(str) {
|
|
235
|
+
if (str.indexOf("%") === -1)
|
|
236
|
+
return str;
|
|
237
|
+
try {
|
|
238
|
+
return decodeURIComponent(str);
|
|
239
|
+
}
|
|
240
|
+
catch (e) {
|
|
241
|
+
return str;
|
|
242
|
+
}
|
|
243
|
+
}
|
|
244
|
+
/**
|
|
245
|
+
* Determine if value is a Date.
|
|
246
|
+
*/
|
|
247
|
+
function isDate(val) {
|
|
248
|
+
return __toString.call(val) === "[object Date]";
|
|
249
|
+
}
|
|
250
|
+
|
|
251
|
+
return dist;
|
|
252
|
+
}
|
|
253
|
+
|
|
254
|
+
var distExports = requireDist();
|
|
255
|
+
|
|
256
|
+
function hasDocumentCookie() {
|
|
257
|
+
const testingValue = typeof global === 'undefined'
|
|
258
|
+
? undefined
|
|
259
|
+
: global.TEST_HAS_DOCUMENT_COOKIE;
|
|
260
|
+
if (typeof testingValue === 'boolean') {
|
|
261
|
+
return testingValue;
|
|
262
|
+
}
|
|
263
|
+
// Can we get/set cookies on document.cookie?
|
|
264
|
+
return typeof document === 'object' && typeof document.cookie === 'string';
|
|
265
|
+
}
|
|
266
|
+
function parseCookies(cookies) {
|
|
267
|
+
if (typeof cookies === 'string') {
|
|
268
|
+
return distExports.parse(cookies);
|
|
269
|
+
}
|
|
270
|
+
else if (typeof cookies === 'object' && cookies !== null) {
|
|
271
|
+
return cookies;
|
|
272
|
+
}
|
|
273
|
+
else {
|
|
274
|
+
return {};
|
|
275
|
+
}
|
|
276
|
+
}
|
|
277
|
+
function readCookie(value, options = {}) {
|
|
278
|
+
const cleanValue = cleanupCookieValue(value);
|
|
279
|
+
if (!options.doNotParse) {
|
|
280
|
+
try {
|
|
281
|
+
return JSON.parse(cleanValue);
|
|
282
|
+
}
|
|
283
|
+
catch (e) {
|
|
284
|
+
// At least we tried
|
|
285
|
+
}
|
|
286
|
+
}
|
|
287
|
+
// Ignore clean value if we failed the deserialization
|
|
288
|
+
// It is not relevant anymore to trim those values
|
|
289
|
+
return value;
|
|
290
|
+
}
|
|
291
|
+
function cleanupCookieValue(value) {
|
|
292
|
+
// express prepend j: before serializing a cookie
|
|
293
|
+
if (value && value[0] === 'j' && value[1] === ':') {
|
|
294
|
+
return value.substr(2);
|
|
295
|
+
}
|
|
296
|
+
return value;
|
|
297
|
+
}
|
|
298
|
+
|
|
299
|
+
class Cookies {
|
|
300
|
+
constructor(cookies, defaultSetOptions = {}) {
|
|
301
|
+
this.changeListeners = [];
|
|
302
|
+
this.HAS_DOCUMENT_COOKIE = false;
|
|
303
|
+
this.update = () => {
|
|
304
|
+
if (!this.HAS_DOCUMENT_COOKIE) {
|
|
305
|
+
return;
|
|
306
|
+
}
|
|
307
|
+
const previousCookies = this.cookies;
|
|
308
|
+
this.cookies = distExports.parse(document.cookie);
|
|
309
|
+
this._checkChanges(previousCookies);
|
|
310
|
+
};
|
|
311
|
+
const domCookies = typeof document === 'undefined' ? '' : document.cookie;
|
|
312
|
+
this.cookies = parseCookies(cookies || domCookies);
|
|
313
|
+
this.defaultSetOptions = defaultSetOptions;
|
|
314
|
+
this.HAS_DOCUMENT_COOKIE = hasDocumentCookie();
|
|
315
|
+
}
|
|
316
|
+
_emitChange(params) {
|
|
317
|
+
for (let i = 0; i < this.changeListeners.length; ++i) {
|
|
318
|
+
this.changeListeners[i](params);
|
|
319
|
+
}
|
|
320
|
+
}
|
|
321
|
+
_checkChanges(previousCookies) {
|
|
322
|
+
const names = new Set(Object.keys(previousCookies).concat(Object.keys(this.cookies)));
|
|
323
|
+
names.forEach((name) => {
|
|
324
|
+
if (previousCookies[name] !== this.cookies[name]) {
|
|
325
|
+
this._emitChange({
|
|
326
|
+
name,
|
|
327
|
+
value: readCookie(this.cookies[name]),
|
|
328
|
+
});
|
|
329
|
+
}
|
|
330
|
+
});
|
|
331
|
+
}
|
|
332
|
+
_startPolling() {
|
|
333
|
+
this.pollingInterval = setInterval(this.update, 300);
|
|
334
|
+
}
|
|
335
|
+
_stopPolling() {
|
|
336
|
+
if (this.pollingInterval) {
|
|
337
|
+
clearInterval(this.pollingInterval);
|
|
338
|
+
}
|
|
339
|
+
}
|
|
340
|
+
get(name, options = {}) {
|
|
341
|
+
if (!options.doNotUpdate) {
|
|
342
|
+
this.update();
|
|
343
|
+
}
|
|
344
|
+
return readCookie(this.cookies[name], options);
|
|
345
|
+
}
|
|
346
|
+
getAll(options = {}) {
|
|
347
|
+
if (!options.doNotUpdate) {
|
|
348
|
+
this.update();
|
|
349
|
+
}
|
|
350
|
+
const result = {};
|
|
351
|
+
for (let name in this.cookies) {
|
|
352
|
+
result[name] = readCookie(this.cookies[name], options);
|
|
353
|
+
}
|
|
354
|
+
return result;
|
|
355
|
+
}
|
|
356
|
+
set(name, value, options) {
|
|
357
|
+
if (options) {
|
|
358
|
+
options = Object.assign(Object.assign({}, this.defaultSetOptions), options);
|
|
359
|
+
}
|
|
360
|
+
else {
|
|
361
|
+
options = this.defaultSetOptions;
|
|
362
|
+
}
|
|
363
|
+
const stringValue = typeof value === 'string' ? value : JSON.stringify(value);
|
|
364
|
+
this.cookies = Object.assign(Object.assign({}, this.cookies), { [name]: stringValue });
|
|
365
|
+
if (this.HAS_DOCUMENT_COOKIE) {
|
|
366
|
+
document.cookie = distExports.serialize(name, stringValue, options);
|
|
367
|
+
}
|
|
368
|
+
this._emitChange({ name, value, options });
|
|
369
|
+
}
|
|
370
|
+
remove(name, options) {
|
|
371
|
+
const finalOptions = (options = Object.assign(Object.assign(Object.assign({}, this.defaultSetOptions), options), { expires: new Date(1970, 1, 1, 0, 0, 1), maxAge: 0 }));
|
|
372
|
+
this.cookies = Object.assign({}, this.cookies);
|
|
373
|
+
delete this.cookies[name];
|
|
374
|
+
if (this.HAS_DOCUMENT_COOKIE) {
|
|
375
|
+
document.cookie = distExports.serialize(name, '', finalOptions);
|
|
376
|
+
}
|
|
377
|
+
this._emitChange({ name, value: undefined, options });
|
|
378
|
+
}
|
|
379
|
+
addChangeListener(callback) {
|
|
380
|
+
this.changeListeners.push(callback);
|
|
381
|
+
if (this.HAS_DOCUMENT_COOKIE && this.changeListeners.length === 1) {
|
|
382
|
+
if (typeof window === 'object' && 'cookieStore' in window) {
|
|
383
|
+
window.cookieStore.addEventListener('change', this.update);
|
|
384
|
+
}
|
|
385
|
+
else {
|
|
386
|
+
this._startPolling();
|
|
387
|
+
}
|
|
388
|
+
}
|
|
389
|
+
}
|
|
390
|
+
removeChangeListener(callback) {
|
|
391
|
+
const idx = this.changeListeners.indexOf(callback);
|
|
392
|
+
if (idx >= 0) {
|
|
393
|
+
this.changeListeners.splice(idx, 1);
|
|
394
|
+
}
|
|
395
|
+
if (this.HAS_DOCUMENT_COOKIE && this.changeListeners.length === 0) {
|
|
396
|
+
if (typeof window === 'object' && 'cookieStore' in window) {
|
|
397
|
+
window.cookieStore.removeEventListener('change', this.update);
|
|
398
|
+
}
|
|
399
|
+
else {
|
|
400
|
+
this._stopPolling();
|
|
401
|
+
}
|
|
402
|
+
}
|
|
403
|
+
}
|
|
404
|
+
removeAllChangeListeners() {
|
|
405
|
+
while (this.changeListeners.length > 0) {
|
|
406
|
+
this.removeChangeListener(this.changeListeners[0]);
|
|
407
|
+
}
|
|
408
|
+
}
|
|
409
|
+
}
|
|
410
|
+
|
|
411
|
+
const COOKIE_VALID_DAYS = 1; // 0 = Session cookie
|
|
412
|
+
|
|
413
|
+
// CookieHelper is a class that takes in and lets us pass around the methods provided
|
|
414
|
+
// by `useCookie` react hook in backend code that is connected to the universal-cookies
|
|
415
|
+
// instance created in SSR middleware (and provides browser cookies)
|
|
416
|
+
class CookieHelper {
|
|
417
|
+
get raw() {
|
|
418
|
+
return this.cookies;
|
|
419
|
+
}
|
|
420
|
+
get cookie() {
|
|
421
|
+
return this.set ? this : this.fallback;
|
|
422
|
+
}
|
|
423
|
+
constructor(cookies, setCookie, removeCookie, updateCookies) {
|
|
424
|
+
// Add fallback methods if global cookies not supplied
|
|
425
|
+
if (!cookies || !setCookie || !removeCookie) this.fallback = new Cookies();
|
|
426
|
+
this.cookies = cookies || this.fallback.getAll();
|
|
427
|
+
if (setCookie) this.set = setCookie;
|
|
428
|
+
if (removeCookie) this.remove = removeCookie;
|
|
429
|
+
if (updateCookies) this.update = updateCookies;
|
|
430
|
+
}
|
|
431
|
+
GetCookie(name) {
|
|
432
|
+
const cookie = this.cookies[name];
|
|
433
|
+
if (typeof cookie === 'undefined') {
|
|
434
|
+
return null;
|
|
435
|
+
}
|
|
436
|
+
return cookie;
|
|
437
|
+
}
|
|
438
|
+
SetCookie(name, value, maxAgeDays = COOKIE_VALID_DAYS) {
|
|
439
|
+
// update local cookies object as this is provided as a clone of `req.universalCookies`
|
|
440
|
+
this.cookies[name] = value;
|
|
441
|
+
|
|
442
|
+
// call the passed setCookie method so we can update the `universal-cookie` instance
|
|
443
|
+
// with the change listener attached so the cookies can be set in SSR response
|
|
444
|
+
if (maxAgeDays === 0) this.cookie.set(name, value);else this.cookie.set(name, value, {
|
|
445
|
+
expires: addDays(new Date(), maxAgeDays),
|
|
446
|
+
path: '/'
|
|
447
|
+
});
|
|
448
|
+
}
|
|
449
|
+
DeleteCookie(name) {
|
|
450
|
+
// update local cookies object as this is provided as a clone of `req.universalCookies`
|
|
451
|
+
delete this.cookies[name];
|
|
452
|
+
this.cookie.remove(name, {
|
|
453
|
+
path: '/'
|
|
454
|
+
});
|
|
455
|
+
}
|
|
456
|
+
}
|
|
457
|
+
const addDays = (date = new Date(), days) => {
|
|
458
|
+
const result = new Date(date);
|
|
459
|
+
result.setDate(result.getDate() + days);
|
|
460
|
+
return result;
|
|
461
|
+
};
|
|
462
|
+
|
|
463
|
+
export { BEARER_TOKEN_COOKIE as B, CookieHelper as C, LOGIN_COOKIE as L, REFRESH_TOKEN_COOKIE as R, Cookies as a, findLoginCookies as f };
|
|
464
|
+
//# sourceMappingURL=CookieHelper.class-FTURFpz3.js.map
|