@zengenti/contensis-react-base 4.0.0-beta.1 → 4.0.0-beta.2

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.
Files changed (98) hide show
  1. package/cjs/{App-cf7e3103.js → App-b56aca04.js} +139 -93
  2. package/{esm/App-6e8e803b.js.map → cjs/App-b56aca04.js.map} +1 -1
  3. package/cjs/{ChangePassword.container-a617190b.js → ChangePassword.container-ae35785e.js} +120 -62
  4. package/{esm/ChangePassword.container-ae0f9ce4.js.map → cjs/ChangePassword.container-ae35785e.js.map} +1 -1
  5. package/cjs/{ContensisDeliveryApi-9e32960d.js → ContensisDeliveryApi-4fcf049d.js} +71 -17
  6. package/{esm/ContensisDeliveryApi-c66b0cc3.js.map → cjs/ContensisDeliveryApi-4fcf049d.js.map} +1 -1
  7. package/cjs/CookieConstants-000427db.js.map +1 -1
  8. package/cjs/{RouteLoader-3e284fd6.js → RouteLoader-c06dccd5.js} +182 -63
  9. package/cjs/RouteLoader-c06dccd5.js.map +1 -0
  10. package/cjs/{ToJs-149fc5e1.js → ToJs-a8d8f3f0.js} +14 -6
  11. package/cjs/{ToJs-149fc5e1.js.map → ToJs-a8d8f3f0.js.map} +1 -1
  12. package/cjs/client.js +20 -14
  13. package/cjs/client.js.map +1 -1
  14. package/cjs/contensis-react-base.js +275 -139
  15. package/cjs/contensis-react-base.js.map +1 -1
  16. package/cjs/forms.js +717 -228
  17. package/cjs/forms.js.map +1 -1
  18. package/cjs/{fromJSLeaveImmer-7c363211.js → fromJSLeaveImmer-e74c673c.js} +4 -1
  19. package/cjs/{fromJSLeaveImmer-7c363211.js.map → fromJSLeaveImmer-e74c673c.js.map} +1 -1
  20. package/cjs/{reducers-9afb5f89.js → reducers-73a03ef4.js} +31 -10
  21. package/cjs/{reducers-9afb5f89.js.map → reducers-73a03ef4.js.map} +1 -1
  22. package/cjs/redux.js +4 -5
  23. package/cjs/redux.js.map +1 -1
  24. package/cjs/routing.js +6 -4
  25. package/cjs/routing.js.map +1 -1
  26. package/cjs/{sagas-e04b94c1.js → sagas-570f23ba.js} +286 -187
  27. package/cjs/{sagas-e04b94c1.js.map → sagas-570f23ba.js.map} +1 -1
  28. package/cjs/search.js +82 -56
  29. package/cjs/search.js.map +1 -1
  30. package/cjs/{selectors-46b689d0.js → selectors-14caa813.js} +6 -1
  31. package/cjs/selectors-14caa813.js.map +1 -0
  32. package/cjs/urls-6fcaf4c6.js.map +1 -1
  33. package/cjs/user.js +9 -4
  34. package/cjs/user.js.map +1 -1
  35. package/cjs/util.js +55 -35
  36. package/cjs/util.js.map +1 -1
  37. package/cjs/{version-79a027cb.js → version-34d91f68.js} +60 -26
  38. package/cjs/version-34d91f68.js.map +1 -0
  39. package/cjs/{version-afd4f77e.js → version-a410c88e.js} +6 -3
  40. package/cjs/{version-afd4f77e.js.map → version-a410c88e.js.map} +1 -1
  41. package/esm/{App-6e8e803b.js → App-83107d7e.js} +137 -91
  42. package/{cjs/App-cf7e3103.js.map → esm/App-83107d7e.js.map} +1 -1
  43. package/esm/{ChangePassword.container-ae0f9ce4.js → ChangePassword.container-76fd5e9b.js} +120 -62
  44. package/{cjs/ChangePassword.container-a617190b.js.map → esm/ChangePassword.container-76fd5e9b.js.map} +1 -1
  45. package/esm/{ContensisDeliveryApi-c66b0cc3.js → ContensisDeliveryApi-fe57a037.js} +71 -17
  46. package/{cjs/ContensisDeliveryApi-9e32960d.js.map → esm/ContensisDeliveryApi-fe57a037.js.map} +1 -1
  47. package/esm/CookieConstants-3d3b6531.js.map +1 -1
  48. package/esm/RouteLoader-29fd689a.js +310 -0
  49. package/esm/RouteLoader-29fd689a.js.map +1 -0
  50. package/esm/{ToJs-ae860aad.js → ToJs-df57f31d.js} +14 -6
  51. package/esm/{ToJs-ae860aad.js.map → ToJs-df57f31d.js.map} +1 -1
  52. package/esm/client.js +21 -15
  53. package/esm/client.js.map +1 -1
  54. package/esm/contensis-react-base.js +270 -136
  55. package/esm/contensis-react-base.js.map +1 -1
  56. package/esm/forms.js +717 -228
  57. package/esm/forms.js.map +1 -1
  58. package/esm/{fromJSLeaveImmer-e2dacd63.js → fromJSLeaveImmer-0114ffcf.js} +4 -1
  59. package/esm/{fromJSLeaveImmer-e2dacd63.js.map → fromJSLeaveImmer-0114ffcf.js.map} +1 -1
  60. package/esm/{reducers-3d5c37d1.js → reducers-aa8cef1e.js} +31 -10
  61. package/esm/{reducers-3d5c37d1.js.map → reducers-aa8cef1e.js.map} +1 -1
  62. package/esm/redux.js +7 -8
  63. package/esm/redux.js.map +1 -1
  64. package/esm/routing.js +3 -4
  65. package/esm/routing.js.map +1 -1
  66. package/esm/{sagas-933a8fc8.js → sagas-07e82e18.js} +239 -139
  67. package/esm/{sagas-933a8fc8.js.map → sagas-07e82e18.js.map} +1 -1
  68. package/esm/search.js +83 -57
  69. package/esm/search.js.map +1 -1
  70. package/esm/{selectors-01074974.js → selectors-691caf02.js} +6 -1
  71. package/esm/selectors-691caf02.js.map +1 -0
  72. package/esm/urls-eac9a747.js.map +1 -1
  73. package/esm/user.js +11 -6
  74. package/esm/user.js.map +1 -1
  75. package/esm/util.js +55 -35
  76. package/esm/util.js.map +1 -1
  77. package/esm/{version-346a9787.js → version-3d9911e2.js} +60 -26
  78. package/esm/version-3d9911e2.js.map +1 -0
  79. package/esm/{version-0fbd1b82.js → version-9f29becb.js} +6 -3
  80. package/esm/{version-0fbd1b82.js.map → version-9f29becb.js.map} +1 -1
  81. package/models/redux/appstate.d.ts +2 -3
  82. package/models/redux/store/history.d.ts +2 -2
  83. package/models/routing/components/Redirect.d.ts +5 -0
  84. package/models/routing/components/StaticRouteLoader.d.ts +6 -0
  85. package/models/routing/httpContext.d.ts +7 -0
  86. package/models/routing/index.d.ts +3 -0
  87. package/models/routing/redux/actions.d.ts +2 -3
  88. package/models/routing/routes.d.ts +11 -5
  89. package/models/util/ContensisDeliveryApi.d.ts +0 -1
  90. package/models/util/mergeStaticRoutes.d.ts +1 -0
  91. package/package.json +3 -5
  92. package/cjs/RouteLoader-3e284fd6.js.map +0 -1
  93. package/cjs/selectors-46b689d0.js.map +0 -1
  94. package/cjs/version-79a027cb.js.map +0 -1
  95. package/esm/RouteLoader-e3c5505f.js +0 -196
  96. package/esm/RouteLoader-e3c5505f.js.map +0 -1
  97. package/esm/selectors-01074974.js.map +0 -1
  98. package/esm/version-346a9787.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"ChangePassword.container-ae0f9ce4.js","sources":["../src/routing/util/find-contenttype-mapping.ts","../src/user/transformations/mapClientCredentials.js","../src/user/util/ContensisManagementApi.js","../src/user/util/OidcUserManager.ts","../src/user/util/LoginHelper.class.js","../src/user/redux/sagas/login.js","../src/user/redux/actions.js","../src/user/hooks/useLogin.js","../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 '../routes';\n\nexport const findContentTypeMapping = (\n ContentTypeMappings: ContentTypeMapping[],\n contentTypeId: string\n) => ContentTypeMappings.find(ct => ct.contentTypeID === contentTypeId);\n","import { mapJson } from '~/util/json-mapper';\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 => mapJson(obj, clientCredentials);\n","// import { Client } from 'contensis-management-api';\n\nexport const getManagementApiClient = async ({\n bearerToken,\n bearerTokenExpiryDate,\n refreshToken,\n refreshTokenExpiryDate,\n contensisClassicToken,\n username,\n password,\n}) => {\n const rootUrl = SERVERS.api || SERVERS.cms; /* 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.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","/* eslint-disable require-atomic-updates */\nimport { to } from 'await-to-js';\n\nimport { getManagementApiClient } from './ContensisManagementApi';\n\nimport mapClientCredentials from '../transformations/mapClientCredentials';\nimport { createUserManager, userManagerConfig } from './OidcUserManager';\nimport { LOGIN_COOKIE, REFRESH_TOKEN_COOKIE } from './CookieConstants';\n\nconst context = typeof window != 'undefined' ? window : global;\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;\n constructor(cookies) {\n this.cookies = cookies;\n }\n\n SetLoginCookies({ contensisClassicToken, refreshToken }) {\n console.info(\n 'SetLoginCookies:',\n LOGIN_COOKIE,\n contensisClassicToken,\n REFRESH_TOKEN_COOKIE,\n refreshToken\n );\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 };\n }\n\n ClearCachedCredentials() {\n this.cookies.DeleteCookie(LOGIN_COOKIE);\n this.cookies.DeleteCookie(REFRESH_TOKEN_COOKIE);\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 = [];\n for (let i = 0; i < localStorage.length; i++) {\n const key = localStorage.key(i);\n if (typeof key === 'string' && key.startsWith('oidc.'))\n keys.push(localStorage.key(i));\n }\n keys.forEach(key => localStorage.removeItem(key));\n }\n }\n\n async LoginUser({ username, password, clientCredentials }) {\n let credentials = clientCredentials;\n let authenticationState = {\n clientCredentials: null,\n isAuthenticated: false,\n isAuthenticationError: false,\n isError: false,\n };\n let transientClient;\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 credentials = mapClientCredentials(transientClient);\n this.SetLoginCookies(credentials);\n authenticationState = {\n clientCredentials: credentials,\n isAuthenticated: true,\n isAuthenticationError: false,\n isError: false,\n };\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) {\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 static withCookies = cookieHelper => new LoginHelper(cookieHelper);\n\n static GetUserDetails = async client => {\n let userError,\n groupsError,\n user = {},\n groupsResult;\n\n [userError, user] = await to(client.security.users.getCurrent());\n if (user && user.id) {\n [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) user.groups = groupsResult.items;\n\n //If groups call fails then log the error but allow the user to login still\n // eslint-disable-next-line no-console\n if (groupsError) console.log(groupsError);\n }\n return [userError, user];\n };\n\n static ClientRedirectToHome(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) {\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) {\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 = `${window.location.pathname}${\n params.toString() ? `?${params}` : ''\n }`;\n }\n }\n\n static async WsFedLogout(redirectPath) {\n await fetch(\n `${LoginHelper.CMS_URL}/authenticate/logout?jsonResponseRequired=true`,\n {\n credentials: 'include',\n }\n );\n if (redirectPath) {\n window.location = 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) {\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","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) {\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 }) {\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 = {}) {\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 }) {\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';\n\nexport const loginUser = (username, password, cookies) =>\n action(LOGIN_USER, { username, password, cookies });\n\nexport const logoutUser = (redirectPath, cookies) =>\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, password) =>\n dispatch(loginUser(username, password, cookies)),\n logoutUser: redirectPath => 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","api","cms","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","SetLoginCookies","info","LOGIN_COOKIE","REFRESH_TOKEN_COOKIE","SetCookie","GetCachedCredentials","GetCookie","ClearCachedCredentials","DeleteCookie","localStorage","keys","i","length","key","startsWith","push","forEach","removeItem","LoginUser","credentials","authenticationState","isAuthenticated","isAuthenticationError","isError","transientClient","user","loginError","clientBearerToken","to","ensureBearerToken","errorMessage","message","name","includes","mapClientCredentials","userDetails","GetUserDetails","latestCredentials","LogoutUser","redirectPath","WsFedLogout","ClientRedirectToPath","ClientRedirectToSignInPage","ClientRedirectToHome","url","search","hash","href","WsFedLogin","LOGIN_ROUTE","replace","GetAccessDeniedRoute","originalPath","ACCESS_DENIED_ROUTE","ClientRedirectToAccessDeniedPage","redirectUri","userManager","signinRedirect","RemoveSecurityTokenQuery","params","URLSearchParams","has","delete","pathname","fetch","CMS_URL","GetCredentialsForSecurityToken","securityToken","response","method","headers","Accept","body","JSON","stringify","encodeURIComponent","ok","parseError","json","LogonResult","ApplicationData","data","item","Key","Value","undefined","status","statusText","withCookies","cookieHelper","userError","groupsError","groupsResult","security","users","getCurrent","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","CookieHelper","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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"}
1
+ {"version":3,"file":"ChangePassword.container-ae35785e.js","sources":["../src/routing/util/find-contenttype-mapping.ts","../src/user/transformations/mapClientCredentials.js","../src/user/util/ContensisManagementApi.js","../src/user/util/OidcUserManager.ts","../src/user/util/LoginHelper.class.js","../src/user/redux/sagas/login.js","../src/user/redux/actions.js","../src/user/hooks/useLogin.js","../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 '../routes';\n\nexport const findContentTypeMapping = (\n ContentTypeMappings: ContentTypeMapping[],\n contentTypeId: string\n) => ContentTypeMappings.find(ct => ct.contentTypeID === contentTypeId);\n","import { mapJson } from '~/util/json-mapper';\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 => mapJson(obj, clientCredentials);\n","// import { Client } from 'contensis-management-api';\n\nexport const getManagementApiClient = async ({\n bearerToken,\n bearerTokenExpiryDate,\n refreshToken,\n refreshTokenExpiryDate,\n contensisClassicToken,\n username,\n password,\n}) => {\n const rootUrl = SERVERS.api || SERVERS.cms; /* 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.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","/* eslint-disable require-atomic-updates */\nimport { to } from 'await-to-js';\n\nimport { getManagementApiClient } from './ContensisManagementApi';\n\nimport mapClientCredentials from '../transformations/mapClientCredentials';\nimport { createUserManager, userManagerConfig } from './OidcUserManager';\nimport { LOGIN_COOKIE, REFRESH_TOKEN_COOKIE } from './CookieConstants';\n\nconst context = typeof window != 'undefined' ? window : global;\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;\n constructor(cookies) {\n this.cookies = cookies;\n }\n\n SetLoginCookies({ contensisClassicToken, refreshToken }) {\n console.info(\n 'SetLoginCookies:',\n LOGIN_COOKIE,\n contensisClassicToken,\n REFRESH_TOKEN_COOKIE,\n refreshToken\n );\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 };\n }\n\n ClearCachedCredentials() {\n this.cookies.DeleteCookie(LOGIN_COOKIE);\n this.cookies.DeleteCookie(REFRESH_TOKEN_COOKIE);\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 = [];\n for (let i = 0; i < localStorage.length; i++) {\n const key = localStorage.key(i);\n if (typeof key === 'string' && key.startsWith('oidc.'))\n keys.push(localStorage.key(i));\n }\n keys.forEach(key => localStorage.removeItem(key));\n }\n }\n\n async LoginUser({ username, password, clientCredentials }) {\n let credentials = clientCredentials;\n let authenticationState = {\n clientCredentials: null,\n isAuthenticated: false,\n isAuthenticationError: false,\n isError: false,\n };\n let transientClient;\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 credentials = mapClientCredentials(transientClient);\n this.SetLoginCookies(credentials);\n authenticationState = {\n clientCredentials: credentials,\n isAuthenticated: true,\n isAuthenticationError: false,\n isError: false,\n };\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) {\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 static withCookies = cookieHelper => new LoginHelper(cookieHelper);\n\n static GetUserDetails = async client => {\n let userError,\n groupsError,\n user = {},\n groupsResult;\n\n [userError, user] = await to(client.security.users.getCurrent());\n if (user && user.id) {\n [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) user.groups = groupsResult.items;\n\n //If groups call fails then log the error but allow the user to login still\n // eslint-disable-next-line no-console\n if (groupsError) console.log(groupsError);\n }\n return [userError, user];\n };\n\n static ClientRedirectToHome(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) {\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) {\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 = `${window.location.pathname}${\n params.toString() ? `?${params}` : ''\n }`;\n }\n }\n\n static async WsFedLogout(redirectPath) {\n await fetch(\n `${LoginHelper.CMS_URL}/authenticate/logout?jsonResponseRequired=true`,\n {\n credentials: 'include',\n }\n );\n if (redirectPath) {\n window.location = 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) {\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","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) {\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 }) {\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 = {}) {\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 }) {\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';\n\nexport const loginUser = (username, password, cookies) =>\n action(LOGIN_USER, { username, password, cookies });\n\nexport const logoutUser = (redirectPath, cookies) =>\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, password) =>\n dispatch(loginUser(username, password, cookies)),\n logoutUser: redirectPath => 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","api","cms","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","SetLoginCookies","info","LOGIN_COOKIE","REFRESH_TOKEN_COOKIE","SetCookie","GetCachedCredentials","GetCookie","ClearCachedCredentials","DeleteCookie","localStorage","keys","i","length","key","startsWith","push","forEach","removeItem","LoginUser","credentials","authenticationState","isAuthenticated","isAuthenticationError","isError","transientClient","user","loginError","clientBearerToken","to","ensureBearerToken","errorMessage","message","name","includes","mapClientCredentials","userDetails","GetUserDetails","latestCredentials","LogoutUser","redirectPath","WsFedLogout","ClientRedirectToPath","ClientRedirectToSignInPage","ClientRedirectToHome","url","search","hash","href","WsFedLogin","LOGIN_ROUTE","replace","GetAccessDeniedRoute","originalPath","ACCESS_DENIED_ROUTE","ClientRedirectToAccessDeniedPage","redirectUri","userManager","signinRedirect","RemoveSecurityTokenQuery","params","URLSearchParams","has","delete","pathname","fetch","CMS_URL","GetCredentialsForSecurityToken","securityToken","response","method","headers","Accept","body","JSON","stringify","encodeURIComponent","ok","parseError","json","LogonResult","ApplicationData","data","item","Key","Value","undefined","status","statusText","withCookies","cookieHelper","userError","groupsError","groupsResult","security","users","getCurrent","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","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","CookieHelper","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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"}
@@ -2,8 +2,8 @@
2
2
 
3
3
  var contensisDeliveryApi = require('contensis-delivery-api');
4
4
  var queryString = require('query-string');
5
- var selectors = require('./selectors-46b689d0.js');
6
- var version = require('./version-79a027cb.js');
5
+ var selectors = require('./selectors-14caa813.js');
6
+ var version = require('./version-34d91f68.js');
7
7
  var CookieConstants = require('./CookieConstants-000427db.js');
8
8
 
9
9
  class CacheNode {
@@ -13,7 +13,9 @@ class CacheNode {
13
13
  this.next = null;
14
14
  this.prev = null;
15
15
  }
16
+
16
17
  }
18
+
17
19
  class LruCache {
18
20
  constructor(limit = 100) {
19
21
  this.map = {};
@@ -22,6 +24,7 @@ class LruCache {
22
24
  this.limit = limit || 100;
23
25
  this.size = 0;
24
26
  }
27
+
25
28
  get(key) {
26
29
  if (this.map[key]) {
27
30
  let value = this.map[key].value;
@@ -31,8 +34,10 @@ class LruCache {
31
34
  return value;
32
35
  }
33
36
  }
37
+
34
38
  set(key, value) {
35
39
  let node = new CacheNode(key, value);
40
+
36
41
  if (this.map[key]) {
37
42
  this.remove(key);
38
43
  } else {
@@ -43,21 +48,28 @@ class LruCache {
43
48
  this.tail.next = null;
44
49
  }
45
50
  }
51
+
46
52
  this.setHead(node);
47
53
  }
54
+
48
55
  setHead(node) {
49
56
  node.next = this.head;
50
57
  node.prev = null;
58
+
51
59
  if (this.head) {
52
60
  this.head.prev = node;
53
61
  }
62
+
54
63
  this.head = node;
64
+
55
65
  if (!this.tail) {
56
66
  this.tail = node;
57
67
  }
68
+
58
69
  this.size++;
59
70
  this.map[node.key] = node;
60
71
  }
72
+
61
73
  remove(key) {
62
74
  let node = this.map[key];
63
75
  if (!node) return; // This is sometimes null and crashes the container without this check
@@ -67,14 +79,17 @@ class LruCache {
67
79
  } else {
68
80
  this.head = node.next;
69
81
  }
82
+
70
83
  if (node.next) {
71
84
  node.next.prev = node.prev;
72
85
  } else {
73
86
  this.tail = node.prev;
74
87
  }
88
+
75
89
  delete this.map[key];
76
90
  this.size--;
77
91
  }
92
+
78
93
  }
79
94
 
80
95
  // CachedSearch does not cache results in SSR by design
@@ -84,17 +99,21 @@ class CachedSearch {
84
99
  this.cookies = void 0;
85
100
  this.cookies = cookies;
86
101
  }
102
+
87
103
  getClient(...args) {
88
104
  return new DeliveryApi(this.cookies).getClient(...args);
89
105
  }
106
+
90
107
  search(query, linkDepth = 0, project) {
91
108
  const client = contensisDeliveryApi.Client.create(getClientConfig(project, this.cookies));
92
109
  return this.request(`${project}+${JSON.stringify(query)}+${linkDepth}`, () => client.entries.search(query, linkDepth));
93
110
  }
111
+
94
112
  searchUsingPost(query, linkDepth = 0, project = '') {
95
113
  const client = contensisDeliveryApi.Client.create(getClientConfig(project, this.cookies));
96
114
  return this.request(`${project}+${JSON.stringify(query)}+${linkDepth}`, () => client.entries.searchUsingPost(query, linkDepth));
97
115
  }
116
+
98
117
  get(id, linkDepth = 0, versionStatus = 'published', project) {
99
118
  const client = contensisDeliveryApi.Client.create(getClientConfig(project, this.cookies));
100
119
  client.clientConfig.versionStatus = versionStatus;
@@ -103,30 +122,37 @@ class CachedSearch {
103
122
  linkDepth
104
123
  }));
105
124
  }
125
+
106
126
  getContentType(id, project) {
107
127
  const client = contensisDeliveryApi.Client.create(getClientConfig(project, this.cookies));
108
128
  return this.request(`[CONTENT TYPE] ${id} ${project}`, () => client.contentTypes.get(id));
109
129
  }
130
+
110
131
  getRootNode(options, project) {
111
132
  const client = contensisDeliveryApi.Client.create(getClientConfig(project, this.cookies));
112
133
  return this.request(`${project} / ${JSON.stringify(options)}`, () => client.nodes.getRoot(options));
113
134
  }
135
+
114
136
  getNode(options, project) {
115
137
  const client = contensisDeliveryApi.Client.create(getClientConfig(project, this.cookies));
116
138
  return this.request(`${project} ${options && typeof options !== 'string' ? 'path' in options ? options.path : options.id : options} ${JSON.stringify(options)}`, () => client.nodes.get(options));
117
139
  }
140
+
118
141
  getAncestors(options, project) {
119
142
  const client = contensisDeliveryApi.Client.create(getClientConfig(project, this.cookies));
120
143
  return this.request(`${project} [A] ${options && typeof options !== 'string' && options.id || options} ${JSON.stringify(options)}`, () => client.nodes.getAncestors(options));
121
144
  }
145
+
122
146
  getChildren(options, project) {
123
147
  const client = contensisDeliveryApi.Client.create(getClientConfig(project, this.cookies));
124
148
  return this.request(`${project} [C] ${options && typeof options !== 'string' && options.id || options} ${JSON.stringify(options)}`, () => client.nodes.getChildren(options));
125
149
  }
150
+
126
151
  getSiblings(options, project) {
127
152
  const client = contensisDeliveryApi.Client.create(getClientConfig(project, this.cookies));
128
153
  return this.request(`${project} [S] ${options && typeof options !== 'string' && options.id || options} ${JSON.stringify(options)}`, () => client.nodes.getSiblings(options));
129
154
  }
155
+
130
156
  request(key, execute) {
131
157
  // do not cache results in SSR
132
158
  if (!this.cache.get(key) || typeof window == 'undefined') {
@@ -136,86 +162,107 @@ class CachedSearch {
136
162
  this.cache.remove(key);
137
163
  });
138
164
  }
165
+
139
166
  return this.cache.get(key);
140
167
  }
168
+
141
169
  }
170
+
142
171
  const cachedSearch = new CachedSearch();
143
172
  const cachedSearchWithCookies = cookies => new CachedSearch(cookies);
144
173
 
145
174
  const mapCookieHeader = cookies => typeof cookies === 'object' ? Object.entries(cookies).map(([name, value]) => `${name}=${value}`).join('; ') : cookies;
175
+
146
176
  const getSsrReferer = () => {
147
177
  if (typeof window === 'undefined') {
148
178
  const state = version.reduxStore.getState();
149
179
  const referer = `${selectors.selectCurrentHostname(state)}${selectors.selectCurrentPath(state)}${selectors.selectCurrentSearch(state)}`;
150
180
  return referer;
151
181
  }
182
+
152
183
  return '';
153
184
  };
185
+
154
186
  const storeSurrogateKeys = response => {
155
187
  const keys = response.headers.get ? response.headers.get('surrogate-key') : response.headers.map['surrogate-key'];
156
188
  if (keys) version.reduxStore === null || version.reduxStore === void 0 ? void 0 : version.reduxStore.dispatch(selectors.setSurrogateKeys(keys, response.url));
157
189
  };
190
+
158
191
  const getClientConfig = (project, cookies) => {
159
- const config = DELIVERY_API_CONFIG; /* global DELIVERY_API_CONFIG */
192
+ const config = DELIVERY_API_CONFIG;
193
+ /* global DELIVERY_API_CONFIG */
194
+
160
195
  config.responseHandler = {};
196
+
161
197
  if (project) {
162
198
  config.projectId = project;
163
- }
199
+ } // we only want the surrogate key header in a server context
200
+
164
201
 
165
- // we only want the surrogate key header in a server context
166
202
  if (typeof window === 'undefined') {
167
203
  config.defaultHeaders = Object.assign(config.defaultHeaders || {}, {
168
204
  referer: getSsrReferer(),
169
205
  'x-require-surrogate-key': true,
170
206
  'x-crb-ssr': true // add this for support tracing
171
- });
172
207
 
208
+ });
173
209
  config.responseHandler[200] = storeSurrogateKeys;
174
210
  }
175
- if (typeof window !== 'undefined' && PROXY_DELIVERY_API /* global PROXY_DELIVERY_API */) {
211
+
212
+ if (typeof window !== 'undefined' && PROXY_DELIVERY_API
213
+ /* global PROXY_DELIVERY_API */
214
+ ) {
176
215
  // ensure a relative url is used to bypass the need for CORS (separate OPTIONS calls)
177
216
  config.rootUrl = '';
217
+
178
218
  config.responseHandler[404] = () => null;
179
219
  }
220
+
180
221
  if (cookies) {
181
222
  const cookieHeader = mapCookieHeader(CookieConstants.findLoginCookies(cookies));
223
+
182
224
  if (cookieHeader) {
183
225
  config.defaultHeaders = Object.assign(config.defaultHeaders || {}, {
184
226
  Cookie: cookieHeader
185
227
  });
186
228
  }
187
229
  }
188
- return config;
189
- };
190
230
 
191
- // export * from 'contensis-delivery-api';
231
+ return config;
232
+ }; // export * from 'contensis-delivery-api';
192
233
 
193
234
  class DeliveryApi {
194
235
  constructor(cookies) {
195
236
  this.cookies = void 0;
237
+
196
238
  this.getClientSideVersionStatus = () => {
197
239
  if (typeof window !== 'undefined') {
198
240
  // Allow overriding versionStatus with the querystring
199
241
  const {
200
242
  versionStatus
201
243
  } = queryString.parse(window.location.search);
202
- if (versionStatus) return versionStatus;
203
- // Client-side we will have a global variable set if rendered by SSR in production
204
- if (typeof window.versionStatus !== 'undefined') return window.versionStatus;
205
- // For localhost development we can only work out versionStatus from the current hostname
244
+ if (versionStatus) return versionStatus; // Client-side we will have a global variable set if rendered by SSR in production
245
+
246
+ if (typeof window.versionStatus !== 'undefined') return window.versionStatus; // For localhost development we can only work out versionStatus from the current hostname
247
+
206
248
  const currentHostname = window.location.hostname;
207
249
  return this.getVersionStatusFromHostname(currentHostname);
208
250
  }
251
+
209
252
  return null;
210
253
  };
254
+
211
255
  this.getServerSideVersionStatus = request => request.query.versionStatus || deliveryApi.getVersionStatusFromHeaders(request.headers) || deliveryApi.getVersionStatusFromHostname(request.hostname);
256
+
212
257
  this.getVersionStatusFromHeaders = headers => {
213
258
  const versionStatusHeader = headers['x-entry-versionstatus'];
214
259
  if (typeof versionStatusHeader !== 'undefined') return versionStatusHeader;
215
260
  return null;
216
261
  };
262
+
217
263
  this.getVersionStatusFromHostname = currentHostname => {
218
264
  if (currentHostname.indexOf('localhost') > -1) return 'latest';
265
+
219
266
  if (currentHostname.endsWith('contensis.cloud')) {
220
267
  if (currentHostname.indexOf('preview.') > -1) {
221
268
  return 'latest';
@@ -223,6 +270,7 @@ class DeliveryApi {
223
270
  return 'published';
224
271
  }
225
272
  }
273
+
226
274
  if (currentHostname.endsWith('cloud.contensis.com')) {
227
275
  if (currentHostname.indexOf('preview-') > -1) {
228
276
  return 'latest';
@@ -230,29 +278,35 @@ class DeliveryApi {
230
278
  return 'published';
231
279
  }
232
280
  }
281
+
233
282
  return 'published';
234
283
  };
284
+
235
285
  this.search = (query, linkDepth = 0, project) => {
236
286
  const client = contensisDeliveryApi.Client.create(getClientConfig(project, this.cookies));
237
287
  return client.entries.search(query, typeof linkDepth !== 'undefined' ? linkDepth : 1);
238
288
  };
289
+
239
290
  this.getClient = (versionStatus = 'published', project) => {
240
291
  const baseConfig = getClientConfig(project, this.cookies);
241
292
  baseConfig.versionStatus = versionStatus;
242
293
  return contensisDeliveryApi.Client.create(baseConfig);
243
294
  };
295
+
244
296
  this.getEntry = (id, linkDepth = 0, versionStatus = 'published', project) => {
245
297
  const baseConfig = getClientConfig(project, this.cookies);
246
298
  baseConfig.versionStatus = versionStatus;
247
- const client = contensisDeliveryApi.Client.create(baseConfig);
248
- // return client.entries.get(id, linkDepth);
299
+ const client = contensisDeliveryApi.Client.create(baseConfig); // return client.entries.get(id, linkDepth);
300
+
249
301
  return client.entries.get({
250
302
  id,
251
303
  linkDepth
252
304
  });
253
305
  };
306
+
254
307
  this.cookies = cookies;
255
308
  }
309
+
256
310
  }
257
311
  const deliveryApi = new DeliveryApi();
258
312
  const deliveryApiWithCookies = cookies => new DeliveryApi(cookies);
@@ -262,4 +316,4 @@ exports.cachedSearchWithCookies = cachedSearchWithCookies;
262
316
  exports.deliveryApi = deliveryApi;
263
317
  exports.deliveryApiWithCookies = deliveryApiWithCookies;
264
318
  exports.getClientConfig = getClientConfig;
265
- //# sourceMappingURL=ContensisDeliveryApi-9e32960d.js.map
319
+ //# sourceMappingURL=ContensisDeliveryApi-4fcf049d.js.map