@zengenti/contensis-react-base 3.0.2-beta.13 → 3.0.2-beta.15
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/cjs/{App-81a45001.js → App-894e9f47.js} +13 -12
- package/cjs/App-894e9f47.js.map +1 -0
- package/cjs/{ContensisDeliveryApi-de88df2a.js → ContensisDeliveryApi-cab9b34d.js} +3 -3
- package/cjs/{ContensisDeliveryApi-de88df2a.js.map → ContensisDeliveryApi-cab9b34d.js.map} +1 -1
- package/cjs/{RouteLoader-47d70a26.js → RouteLoader-8e8605bc.js} +3 -3
- package/cjs/{RouteLoader-47d70a26.js.map → RouteLoader-8e8605bc.js.map} +1 -1
- package/cjs/{ToJs-61c03582.js → ToJs-31139698.js} +2 -2
- package/cjs/{ToJs-61c03582.js.map → ToJs-31139698.js.map} +1 -1
- package/cjs/client.js +8 -8
- package/cjs/contensis-react-base.js +9 -9
- package/cjs/{login-51b66359.js → login-56149a73.js} +3 -3
- package/cjs/{login-51b66359.js.map → login-56149a73.js.map} +1 -1
- package/cjs/redux.js +3 -3
- package/cjs/routing.js +3 -3
- package/cjs/{sagas-e122fc26.js → sagas-e04b94c1.js} +23 -15
- package/cjs/sagas-e04b94c1.js.map +1 -0
- package/cjs/search.js +13 -13
- package/cjs/search.js.map +1 -1
- package/cjs/{selectors-c76c2676.js → selectors-1ab616aa.js} +5 -1
- package/cjs/selectors-1ab616aa.js.map +1 -0
- package/cjs/user.js +3 -3
- package/cjs/util.js +3 -3
- package/cjs/{version-38afaf2a.js → version-0d11a071.js} +7 -3
- package/cjs/version-0d11a071.js.map +1 -0
- package/cjs/{version-886f49d8.js → version-6ce30b57.js} +3 -3
- package/cjs/{version-886f49d8.js.map → version-6ce30b57.js.map} +1 -1
- package/esm/{App-5f914483.js → App-accee6b9.js} +13 -12
- package/esm/App-accee6b9.js.map +1 -0
- package/esm/{ContensisDeliveryApi-ad06857d.js → ContensisDeliveryApi-fc68ef5e.js} +3 -3
- package/esm/{ContensisDeliveryApi-ad06857d.js.map → ContensisDeliveryApi-fc68ef5e.js.map} +1 -1
- package/esm/{RouteLoader-f5d5f733.js → RouteLoader-46031747.js} +3 -3
- package/esm/{RouteLoader-f5d5f733.js.map → RouteLoader-46031747.js.map} +1 -1
- package/esm/{ToJs-0066e629.js → ToJs-4a595f89.js} +2 -2
- package/esm/{ToJs-0066e629.js.map → ToJs-4a595f89.js.map} +1 -1
- package/esm/client.js +9 -9
- package/esm/contensis-react-base.js +10 -10
- package/esm/{login-4d07c2de.js → login-2427614b.js} +3 -3
- package/esm/{login-4d07c2de.js.map → login-2427614b.js.map} +1 -1
- package/esm/redux.js +6 -6
- package/esm/routing.js +3 -3
- package/esm/{sagas-0efcf4b0.js → sagas-933a8fc8.js} +23 -15
- package/esm/sagas-933a8fc8.js.map +1 -0
- package/esm/search.js +14 -14
- package/esm/search.js.map +1 -1
- package/esm/{selectors-3f0d804d.js → selectors-0b9508f4.js} +5 -1
- package/esm/selectors-0b9508f4.js.map +1 -0
- package/esm/user.js +4 -4
- package/esm/util.js +3 -3
- package/esm/{version-dd31c7f0.js → version-0160e6b9.js} +7 -3
- package/esm/version-0160e6b9.js.map +1 -0
- package/esm/{version-f4629693.js → version-cef1a76d.js} +3 -3
- package/esm/{version-f4629693.js.map → version-cef1a76d.js.map} +1 -1
- package/models/redux/appstate.d.ts +1 -0
- package/models/routing/redux/selectors.d.ts +1 -0
- package/models/search/models/SearchActions.d.ts +3 -3
- package/models/search/redux/actions.d.ts +6 -6
- package/models/search/redux/util.d.ts +1 -1
- package/package.json +1 -1
- package/cjs/App-81a45001.js.map +0 -1
- package/cjs/sagas-e122fc26.js.map +0 -1
- package/cjs/selectors-c76c2676.js.map +0 -1
- package/cjs/version-38afaf2a.js.map +0 -1
- package/esm/App-5f914483.js.map +0 -1
- package/esm/sagas-0efcf4b0.js.map +0 -1
- package/esm/selectors-3f0d804d.js.map +0 -1
- package/esm/version-dd31c7f0.js.map +0 -1
package/esm/client.js
CHANGED
|
@@ -7,12 +7,12 @@ import { Router } from 'react-router-dom';
|
|
|
7
7
|
import { loadableReady } from '@loadable/component';
|
|
8
8
|
import { parse } from 'query-string';
|
|
9
9
|
import { CookiesProvider } from 'react-cookie';
|
|
10
|
-
import { c as createStore, s as selectVersionStatus } from './version-
|
|
11
|
-
import { s as setVersionStatus } from './version-
|
|
12
|
-
import { b as browserHistory, r as rootSaga, p as pickProject } from './App-
|
|
13
|
-
export { A as ReactApp } from './App-
|
|
14
|
-
import { c as setCurrentProject } from './selectors-
|
|
15
|
-
import { d as deliveryApi } from './ContensisDeliveryApi-
|
|
10
|
+
import { c as createStore, s as selectVersionStatus } from './version-0160e6b9.js';
|
|
11
|
+
import { s as setVersionStatus } from './version-cef1a76d.js';
|
|
12
|
+
import { b as browserHistory, r as rootSaga, p as pickProject } from './App-accee6b9.js';
|
|
13
|
+
export { A as ReactApp } from './App-accee6b9.js';
|
|
14
|
+
import { c as setCurrentProject } from './selectors-0b9508f4.js';
|
|
15
|
+
import { d as deliveryApi } from './ContensisDeliveryApi-fc68ef5e.js';
|
|
16
16
|
import 'redux';
|
|
17
17
|
import 'redux-thunk';
|
|
18
18
|
import 'redux-saga';
|
|
@@ -23,13 +23,13 @@ import './reducers-3d5c37d1.js';
|
|
|
23
23
|
import '@redux-saga/core/effects';
|
|
24
24
|
import 'history';
|
|
25
25
|
import 'loglevel';
|
|
26
|
-
import './login-
|
|
27
|
-
import './ToJs-
|
|
26
|
+
import './login-2427614b.js';
|
|
27
|
+
import './ToJs-4a595f89.js';
|
|
28
28
|
import 'jsonpath-mapper';
|
|
29
29
|
import 'await-to-js';
|
|
30
30
|
import 'js-cookie';
|
|
31
31
|
import 'contensis-delivery-api';
|
|
32
|
-
import './RouteLoader-
|
|
32
|
+
import './RouteLoader-46031747.js';
|
|
33
33
|
import 'react-router-config';
|
|
34
34
|
import 'reselect';
|
|
35
35
|
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { c as cachedSearch, d as deliveryApi } from './ContensisDeliveryApi-
|
|
1
|
+
import { c as cachedSearch, d as deliveryApi } from './ContensisDeliveryApi-fc68ef5e.js';
|
|
2
2
|
import { Query as Query$1 } from 'contensis-delivery-api';
|
|
3
3
|
import React from 'react';
|
|
4
4
|
import { Provider } from 'react-redux';
|
|
@@ -6,7 +6,7 @@ import mapJson from 'jsonpath-mapper';
|
|
|
6
6
|
import 'reselect';
|
|
7
7
|
import 'deepmerge';
|
|
8
8
|
import 'query-string';
|
|
9
|
-
import { d as defaultExpressions, c as contentTypeIdExpression, f as filterExpressions, t as termExpressions, o as orderByExpression, a as customWhereExpressions } from './sagas-
|
|
9
|
+
import { d as defaultExpressions, c as contentTypeIdExpression, f as filterExpressions, t as termExpressions, o as orderByExpression, a as customWhereExpressions } from './sagas-933a8fc8.js';
|
|
10
10
|
import 'immer';
|
|
11
11
|
import 'deep-equal';
|
|
12
12
|
import { Op, Query } from 'contensis-core-api';
|
|
@@ -29,11 +29,11 @@ import { ChunkExtractor, ChunkExtractorManager } from '@loadable/server';
|
|
|
29
29
|
import { identity, noop } from 'lodash';
|
|
30
30
|
import { buildCleaner } from 'lodash-clean';
|
|
31
31
|
import { CookiesProvider } from 'react-cookie';
|
|
32
|
-
import { c as createStore } from './version-
|
|
33
|
-
import { h as history, p as pickProject, r as rootSaga } from './App-
|
|
34
|
-
export { A as ReactApp } from './App-
|
|
35
|
-
import { s as setVersionStatus, a as setVersion } from './version-
|
|
36
|
-
import { s as selectSurrogateKeys, a as selectRouteEntry, b as selectCurrentProject, g as getImmutableOrJS, c as setCurrentProject } from './selectors-
|
|
32
|
+
import { c as createStore } from './version-0160e6b9.js';
|
|
33
|
+
import { h as history, p as pickProject, r as rootSaga } from './App-accee6b9.js';
|
|
34
|
+
export { A as ReactApp } from './App-accee6b9.js';
|
|
35
|
+
import { s as setVersionStatus, a as setVersion } from './version-cef1a76d.js';
|
|
36
|
+
import { s as selectSurrogateKeys, a as selectRouteEntry, b as selectCurrentProject, g as getImmutableOrJS, c as setCurrentProject } from './selectors-0b9508f4.js';
|
|
37
37
|
import chalk from 'chalk';
|
|
38
38
|
import 'loglevel';
|
|
39
39
|
import '@redux-saga/core/effects';
|
|
@@ -43,12 +43,12 @@ import 'redux-saga';
|
|
|
43
43
|
import 'redux-injectors';
|
|
44
44
|
import './reducers-3d5c37d1.js';
|
|
45
45
|
import 'history';
|
|
46
|
-
import './login-
|
|
47
|
-
import './ToJs-
|
|
46
|
+
import './login-2427614b.js';
|
|
47
|
+
import './ToJs-4a595f89.js';
|
|
48
48
|
import 'await-to-js';
|
|
49
49
|
import 'js-cookie';
|
|
50
50
|
import 'react-hot-loader';
|
|
51
|
-
import './RouteLoader-
|
|
51
|
+
import './RouteLoader-46031747.js';
|
|
52
52
|
|
|
53
53
|
/**
|
|
54
54
|
* Util class holds our search results helper boilerplate methods
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { takeEvery, put, call, select } from '@redux-saga/core/effects';
|
|
2
2
|
import { L as LOGIN_USER, n as LOGOUT_USER, V as VALIDATE_USER, S as SET_AUTHENTICATION_STATE } from './reducers-3d5c37d1.js';
|
|
3
|
-
import { a as selectUserIsAuthenticated, b as selectUserGroups, m as matchUserGroup, s as selectClientCredentials } from './ToJs-
|
|
4
|
-
import { q as queryParams, o as selectCurrentSearch, p as setRoute } from './selectors-
|
|
3
|
+
import { a as selectUserIsAuthenticated, b as selectUserGroups, m as matchUserGroup, s as selectClientCredentials } from './ToJs-4a595f89.js';
|
|
4
|
+
import { q as queryParams, o as selectCurrentSearch, p as setRoute } from './selectors-0b9508f4.js';
|
|
5
5
|
import mapJson from 'jsonpath-mapper';
|
|
6
6
|
import { to } from 'await-to-js';
|
|
7
7
|
import JSCookie from 'js-cookie';
|
|
@@ -572,4 +572,4 @@ function* refreshSecurityToken() {
|
|
|
572
572
|
}
|
|
573
573
|
|
|
574
574
|
export { LoginHelper as L, findContentTypeMapping as f, getManagementApiClient as g, handleRequiresLoginSaga as h, loginSagas as l, refreshSecurityToken as r };
|
|
575
|
-
//# sourceMappingURL=login-
|
|
575
|
+
//# sourceMappingURL=login-2427614b.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"login-4d07c2de.js","sources":["../src/routing/util/find-contenttype-mapping.ts","../src/user/transformations/mapClientCredentials.js","../src/user/util/ContensisManagementApi.js","../src/user/util/CookieHelper.class.ts","../src/user/util/OidcUserManager.ts","../src/user/util/LoginHelper.class.js","../src/user/redux/sagas/login.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 const { Client } = await import('contensis-management-api');\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 JSCookie from 'js-cookie';\n\nconst COOKIE_VALID_DAYS = 1; // 0 = Session cookie\n\n// Override the default js-cookie conversion / encoding\n// methods so the written values work with Contensis sites\nconst Cookies = JSCookie.withConverter({\n read: value => decodeURIComponent(value),\n write: value => encodeURIComponent(value),\n});\n\nexport class CookieHelper {\n static GetCookie(name) {\n const cookie = Cookies.get(name);\n if (typeof cookie === 'undefined') {\n return null;\n }\n return cookie;\n }\n\n static SetCookie(name, value, maxAgeDays = COOKIE_VALID_DAYS) {\n if (maxAgeDays === 0) Cookies.set(name, value);\n else Cookies.set(name, value, { expires: maxAgeDays });\n }\n\n static DeleteCookie(name) {\n Cookies.remove(name);\n }\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 { getManagementApiClient } from './ContensisManagementApi';\nimport { to } from 'await-to-js';\n\nimport { CookieHelper } from './CookieHelper.class';\n\nimport mapClientCredentials from '../transformations/mapClientCredentials';\nimport { createUserManager, userManagerConfig } from './OidcUserManager';\n\nconst LOGIN_COOKIE = 'ContensisCMSUserName';\nconst REFRESH_TOKEN_COOKIE = 'RefreshToken';\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 static SetLoginCookies({ contensisClassicToken, refreshToken }) {\n console.info(\n 'SetLoginCookies:',\n LOGIN_COOKIE,\n contensisClassicToken,\n REFRESH_TOKEN_COOKIE,\n refreshToken\n );\n if (contensisClassicToken)\n CookieHelper.SetCookie(LOGIN_COOKIE, contensisClassicToken);\n if (refreshToken)\n CookieHelper.SetCookie(REFRESH_TOKEN_COOKIE, refreshToken);\n }\n\n static GetCachedCredentials() {\n return {\n bearerToken: null,\n bearerTokenExpiryDate: null,\n refreshToken: CookieHelper.GetCookie(REFRESH_TOKEN_COOKIE),\n refreshTokenExpiryDate: null,\n contensisClassicToken: CookieHelper.GetCookie(LOGIN_COOKIE),\n };\n }\n\n static ClearCachedCredentials() {\n CookieHelper.DeleteCookie(LOGIN_COOKIE);\n CookieHelper.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 static 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 LoginHelper.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 LoginHelper.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 LoginHelper.ClearCachedCredentials();\n } else {\n // Ensure we get latest refreshToken and contensisClassicToken from the latest client\n const latestCredentials = mapClientCredentials(client);\n LoginHelper.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 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 LogoutUser(redirectPath) {\n LoginHelper.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 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 (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 ClientRedirectToAccessDeniedPage(originalPath) {\n let url = LoginHelper.ACCESS_DENIED_ROUTE;\n if (originalPath === url) return;\n\n if (typeof originalPath === 'string')\n url = `${url}?original_uri=${originalPath}`;\n if (typeof location !== 'undefined') location.href = url;\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 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 entry,\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 // If routeRequiresLogin do a blocking call that returns userLoggedIn\n userLoggedIn = yield call(validateUserSaga, { securityToken });\n }\n // otherwise do a non blocking put to handle validation in the background\n else yield put({ type: VALIDATE_USER, 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\nfunction* validateUserSaga({ securityToken }) {\n // Check for refreshToken in cookies\n let clientCredentials = LoginHelper.GetCachedCredentials();\n\n if (securityToken || clientCredentials.refreshToken) {\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 const [error, refreshToken] =\n yield LoginHelper.GetCredentialsForSecurityToken(securityToken);\n if (refreshToken) {\n // Set cookies and reload values\n LoginHelper.SetLoginCookies({\n contensisClassicToken: securityToken,\n refreshToken,\n });\n clientCredentials = LoginHelper.GetCachedCredentials();\n }\n\n // Log the user in if a refreshToken is found\n if (clientCredentials.refreshToken)\n yield call(loginUserSaga, { clientCredentials });\n else if (error)\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 // Tell any callers have we successfully logged in?\n return yield select(selectUserIsAuthenticated);\n}\n\nfunction* loginUserSaga(action = {}) {\n const { username, password, clientCredentials } = action;\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 LoginHelper.LoginUser({\n username,\n password,\n clientCredentials,\n });\n\n yield put({\n type: SET_AUTHENTICATION_STATE,\n authenticationState,\n user,\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 }) {\n yield put({\n type: SET_AUTHENTICATION_STATE,\n user: null,\n });\n yield LoginHelper.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"],"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","client","create","COOKIE_VALID_DAYS","Cookies","JSCookie","withConverter","read","value","decodeURIComponent","write","encodeURIComponent","CookieHelper","GetCookie","name","cookie","get","SetCookie","maxAgeDays","set","expires","DeleteCookie","remove","context","window","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","LOGIN_COOKIE","REFRESH_TOKEN_COOKIE","LoginHelper","SetLoginCookies","info","GetCachedCredentials","ClearCachedCredentials","localStorage","keys","i","length","key","startsWith","push","forEach","removeItem","LoginUser","credentials","authenticationState","isAuthenticated","isAuthenticationError","isError","transientClient","user","loginError","clientBearerToken","to","ensureBearerToken","errorMessage","message","includes","mapClientCredentials","userDetails","GetUserDetails","latestCredentials","LogoutUser","redirectPath","WsFedLogout","ClientRedirectToPath","ClientRedirectToSignInPage","ClientRedirectToHome","url","search","hash","href","WsFedLogin","LOGIN_ROUTE","replace","ClientRedirectToAccessDeniedPage","originalPath","ACCESS_DENIED_ROUTE","redirectUri","userManager","signinRedirect","RemoveSecurityTokenQuery","params","URLSearchParams","has","delete","pathname","fetch","CMS_URL","GetCredentialsForSecurityToken","securityToken","response","method","headers","Accept","body","JSON","stringify","ok","parseError","json","LogonResult","ApplicationData","data","item","Key","Value","undefined","status","statusText","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","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","isLoading","removeHostnamePart","path","relativePath","split","splice","join","isLoggedIn","ReturnURL","assetRedirectPath","setRoute","refreshSecurityToken","selectClientCredentials","Object","authenticate"],"mappings":";;;;;;;;MAEaA,sBAAsB,GAAGA,CACpCC,mBAAyC,EACzCC,aAAqB,KAClBD,mBAAmB,CAACE,IAAI,CAACC,EAAE,IAAIA,EAAE,CAACC,aAAa,KAAKH,aAAa;;ACHtE,MAAMI,iBAAiB,GAAG;AACxBC,EAAAA,WAAW,EAAE,aAAa;AAC1BC,EAAAA,qBAAqB,EAAEA,CAAC;AAAEA,IAAAA,qBAAAA;AAAsB,GAAC,KAC/CA,qBAAqB,CAACC,WAAW,EAAE;AACrCC,EAAAA,YAAY,EAAE,cAAc;AAC5BC,EAAAA,sBAAsB,EAAEA,CAAC;AAAEA,IAAAA,sBAAAA;AAAuB,GAAC,KACjDA,sBAAsB,CAACF,WAAW,EAAE;AACtCG,EAAAA,qBAAqB,EAAE,uBAAA;AACzB,CAAC,CAAA;AACD,2BAAA,CAAeC,GAAG,IAAIC,OAAO,CAACD,GAAG,EAAEP,iBAAiB,CAAC;;ACXrD;;AAEaS,MAAAA,sBAAsB,GAAG,OAAO;EAC3CR,WAAW;EACXC,qBAAqB;EACrBE,YAAY;EACZC,sBAAsB;EACtBC,qBAAqB;EACrBI,QAAQ;AACRC,EAAAA,QAAAA;AACF,CAAC,KAAK;EACJ,MAAMC,OAAO,GAAGC,OAAO,CAACC,GAAG,IAAID,OAAO,CAACE,GAAG,CAAC;EAC3C,MAAMC,SAAS,GAAGC,QAAQ,CAAC,CAAC,CAAC,CAACC,EAAE,CAAC;;EAEjC,IAAIC,MAAM,GAAG,EAAE,CAAA;AACf,EAAA,IAAIf,YAAY,EAAE;AAChBe,IAAAA,MAAM,GAAG;AACPC,MAAAA,UAAU,EAAE,iCAAiC;AAC7CC,MAAAA,aAAa,EAAE;AACbjB,QAAAA,YAAAA;AACF,OAAA;KACD,CAAA;AACH,GAAC,MAAM;AACLe,IAAAA,MAAM,GAAG;AACPC,MAAAA,UAAU,EAAE,mBAAmB;AAC/BC,MAAAA,aAAa,EAAE;QACbX,QAAQ;AACRC,QAAAA,QAAAA;AACF,OAAA;KACD,CAAA;AACH,GAAA;EACA,MAAM;AAAEW,IAAAA,MAAAA;AAAO,GAAC,GAAG,MAAM,OAAO,0BAA0B,CAAC,CAAA;AAE3D,EAAA,MAAMC,MAAM,GAAGD,MAAM,CAACE,MAAM,CAAC;AAC3B,IAAA,GAAGL,MAAM;IACTH,SAAS;AACTJ,IAAAA,OAAAA;AACF,GAAC,CAAC,CAAA;AAEF,EAAA,IAAIX,WAAW,EAAEsB,MAAM,CAACtB,WAAW,GAAGA,WAAW,CAAA;AACjD,EAAA,IAAIC,qBAAqB,EACvBqB,MAAM,CAACrB,qBAAqB,GAAGA,qBAAqB,CAAA;AACtD,EAAA,IAAIE,YAAY,EAAEmB,MAAM,CAACnB,YAAY,GAAGA,YAAY,CAAA;AACpD,EAAA,IAAIC,sBAAsB,EACxBkB,MAAM,CAAClB,sBAAsB,GAAGA,sBAAsB,CAAA;AACxD,EAAA,IAAIC,qBAAqB,EACvBiB,MAAM,CAACjB,qBAAqB,GAAGA,qBAAqB,CAAA;AAEtD,EAAA,OAAOiB,MAAM,CAAA;AACf;;AC/CA,MAAME,iBAAiB,GAAG,CAAC,CAAC;;AAE5B;AACA;AACA,MAAMC,OAAO,GAAGC,QAAQ,CAACC,aAAa,CAAC;AACrCC,EAAAA,IAAI,EAAEC,KAAK,IAAIC,kBAAkB,CAACD,KAAK,CAAC;AACxCE,EAAAA,KAAK,EAAEF,KAAK,IAAIG,kBAAkB,CAACH,KAAK,CAAA;AAC1C,CAAC,CAAC,CAAA;AAEK,MAAMI,YAAY,CAAC;EACxB,OAAOC,SAASA,CAACC,IAAI,EAAE;AACrB,IAAA,MAAMC,MAAM,GAAGX,OAAO,CAACY,GAAG,CAACF,IAAI,CAAC,CAAA;AAChC,IAAA,IAAI,OAAOC,MAAM,KAAK,WAAW,EAAE;AACjC,MAAA,OAAO,IAAI,CAAA;AACb,KAAA;AACA,IAAA,OAAOA,MAAM,CAAA;AACf,GAAA;EAEA,OAAOE,SAASA,CAACH,IAAI,EAAEN,KAAK,EAAEU,UAAU,GAAGf,iBAAiB,EAAE;IAC5D,IAAIe,UAAU,KAAK,CAAC,EAAEd,OAAO,CAACe,GAAG,CAACL,IAAI,EAAEN,KAAK,CAAC,CAAC,KAC1CJ,OAAO,CAACe,GAAG,CAACL,IAAI,EAAEN,KAAK,EAAE;AAAEY,MAAAA,OAAO,EAAEF,UAAAA;AAAW,KAAC,CAAC,CAAA;AACxD,GAAA;EAEA,OAAOG,YAAYA,CAACP,IAAI,EAAE;AACxBV,IAAAA,OAAO,CAACkB,MAAM,CAACR,IAAI,CAAC,CAAA;AACtB,GAAA;AACF;;AC1BA,MAAMS,SAAO,GACX,OAAOC,MAAM,IAAI,WAAW,GAAGA,MAAM,GAAGC,MAGzC,CAAA;AAED,MAAMC,WAAW,GACfC,OAAO,CAACC,GAAG,CAACC,QAAQ,KAAK,aAAa,GAClCC,WAAW,KAAK,MAAM,4BACtBP,SAAO,CAACO,WAAW,KAAK,MAAM,CAAA;AAEpC,MAAMC,OAAO,GAAGxC,OAAO,CAAC;;AAEjB,MAAMyC,iBAAiB,GAC5B,OAAOR,MAAM,KAAK,WAAW,GACzB;AACES,EAAAA,SAAS,EAAG,CAAA,EAAEF,OAAO,CAACtC,GAAI,CAAe,cAAA,CAAA;AACzCyC,EAAAA,SAAS,EAAE,mBAAmB;AAC9BC,EAAAA,YAAY,EAAEX,MAAM,CAACY,QAAQ,CAACC,QAAQ,EAAE;AACxCC,EAAAA,wBAAwB,EAAEd,MAAM,CAACY,QAAQ,CAACC,QAAQ,EAAE;AACpDE,EAAAA,aAAa,EAAE,UAAU;AACzBC,EAAAA,KAAK,EAAE,QAAQ;AACfC,EAAAA,oBAAoB,EAAE,KAAA;AACxB,CAAC,GACD,EAAE,CAAA;AAED,MAAMC,iBAAiB,GAAG,MAAO7C,MAA2B,IAAK;AACtE,EAAA,IAAI,OAAO2B,MAAM,KAAK,WAAW,IAAIE,WAAW,EAAE;IAChD,IAAI;MACF,MAAM;AAAEiB,QAAAA,WAAAA;AAAY,OAAC,GAAG,MAAM,4CACS,aAAa,CACnD,CAAA;AACD,MAAA,OAAO,IAAIA,WAAW,CAAC9C,MAAM,CAAC,CAAA;KAC/B,CAAC,OAAO+C,CAAC,EAAE;AACVC,MAAAA,OAAO,CAACC,KAAK,CAAC,kCAAkC,EAAEF,CAAC,CAAC,CAAA;AACtD,KAAA;GACD,MAAM,OAAO,EAAE,CAAA;AAClB,CAAC;;ACvCD;AASA,MAAMG,YAAY,GAAG,sBAAsB,CAAA;AAC3C,MAAMC,oBAAoB,GAAG,cAAc,CAAA;AAE3C,MAAMzB,OAAO,GAAG,OAAOC,MAAM,IAAI,WAAW,GAAGA,MAAM,GAAGC,MAAM,CAAA;AAEvD,MAAMwB,WAAW,CAAC;AASvB,EAAA,OAAOC,eAAeA,CAAC;IAAElE,qBAAqB;AAAEF,IAAAA,YAAAA;AAAa,GAAC,EAAE;AAC9D+D,IAAAA,OAAO,CAACM,IAAI,CACV,kBAAkB,EAClBJ,YAAY,EACZ/D,qBAAqB,EACrBgE,oBAAoB,EACpBlE,YAAY,CACb,CAAA;IACD,IAAIE,qBAAqB,EACvB4B,YAAY,CAACK,SAAS,CAAC8B,YAAY,EAAE/D,qBAAqB,CAAC,CAAA;IAC7D,IAAIF,YAAY,EACd8B,YAAY,CAACK,SAAS,CAAC+B,oBAAoB,EAAElE,YAAY,CAAC,CAAA;AAC9D,GAAA;EAEA,OAAOsE,oBAAoBA,GAAG;IAC5B,OAAO;AACLzE,MAAAA,WAAW,EAAE,IAAI;AACjBC,MAAAA,qBAAqB,EAAE,IAAI;AAC3BE,MAAAA,YAAY,EAAE8B,YAAY,CAACC,SAAS,CAACmC,oBAAoB,CAAC;AAC1DjE,MAAAA,sBAAsB,EAAE,IAAI;AAC5BC,MAAAA,qBAAqB,EAAE4B,YAAY,CAACC,SAAS,CAACkC,YAAY,CAAA;KAC3D,CAAA;AACH,GAAA;EAEA,OAAOM,sBAAsBA,GAAG;AAC9BzC,IAAAA,YAAY,CAACS,YAAY,CAAC0B,YAAY,CAAC,CAAA;AACvCnC,IAAAA,YAAY,CAACS,YAAY,CAAC2B,oBAAoB,CAAC,CAAA;IAE/C,IAAIC,WAAW,CAACnB,WAAW,IAAI,OAAON,MAAM,KAAK,WAAW,EAAE;AAC5D;MACA,MAAM;AAAE8B,QAAAA,YAAAA;AAAa,OAAC,GAAG9B,MAAM,CAAA;MAC/B,MAAM+B,IAAI,GAAG,EAAE,CAAA;AACf,MAAA,KAAK,IAAIC,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGF,YAAY,CAACG,MAAM,EAAED,CAAC,EAAE,EAAE;AAC5C,QAAA,MAAME,GAAG,GAAGJ,YAAY,CAACI,GAAG,CAACF,CAAC,CAAC,CAAA;QAC/B,IAAI,OAAOE,GAAG,KAAK,QAAQ,IAAIA,GAAG,CAACC,UAAU,CAAC,OAAO,CAAC,EACpDJ,IAAI,CAACK,IAAI,CAACN,YAAY,CAACI,GAAG,CAACF,CAAC,CAAC,CAAC,CAAA;AAClC,OAAA;MACAD,IAAI,CAACM,OAAO,CAACH,GAAG,IAAIJ,YAAY,CAACQ,UAAU,CAACJ,GAAG,CAAC,CAAC,CAAA;AACnD,KAAA;AACF,GAAA;AAEA,EAAA,aAAaK,SAASA,CAAC;IAAE3E,QAAQ;IAAEC,QAAQ;AAAEX,IAAAA,iBAAAA;AAAkB,GAAC,EAAE;IAChE,IAAIsF,WAAW,GAAGtF,iBAAiB,CAAA;AACnC,IAAA,IAAIuF,mBAAmB,GAAG;AACxBvF,MAAAA,iBAAiB,EAAE,IAAI;AACvBwF,MAAAA,eAAe,EAAE,KAAK;AACtBC,MAAAA,qBAAqB,EAAE,KAAK;AAC5BC,MAAAA,OAAO,EAAE,KAAA;KACV,CAAA;AACD,IAAA,IAAIC,eAAe,CAAA;AACnB,IAAA,IAAIC,IAAI,CAAA;IAER,IAAIlF,QAAQ,IAAIC,QAAQ,EAAE;AACxB;MACAgF,eAAe,GAAG,MAAMlF,sBAAsB,CAAC;QAC7CC,QAAQ;AACRC,QAAAA,QAAAA;AACF,OAAC,CAAC,CAAA;;AAEF;AACA,MAAA,MAAM,CAACkF,UAAU,EAAEC,iBAAiB,CAAC,GAAG,MAAMC,EAAE,CAC9CJ,eAAe,CAACK,iBAAiB,EAAE,CACpC,CAAA;;AAED;AACA,MAAA,IAAIH,UAAU,EAAE;AACdN,QAAAA,mBAAmB,GAAG;AACpBvF,UAAAA,iBAAiB,EAAE,IAAI;AACvBiG,UAAAA,YAAY,EAAEJ,UAAU,CAACK,OAAO,IAAI,IAAI;AACxCV,UAAAA,eAAe,EAAE,KAAK;UACtBC,qBAAqB,EAAEI,UAAU,CAACzD,IAAI,CAAC+D,QAAQ,CAC7C,8BAA8B,CAC/B;AACDT,UAAAA,OAAO,EAAE,IAAA;SACV,CAAA;QACDnB,WAAW,CAACI,sBAAsB,EAAE,CAAA;AACtC,OAAA;;AAEA;AACA,MAAA,IAAImB,iBAAiB,EAAE;AACrB;AACAR,QAAAA,WAAW,GAAGc,oBAAoB,CAACT,eAAe,CAAC,CAAA;AACnDpB,QAAAA,WAAW,CAACC,eAAe,CAACc,WAAW,CAAC,CAAA;AACxCC,QAAAA,mBAAmB,GAAG;AACpBvF,UAAAA,iBAAiB,EAAEsF,WAAW;AAC9BE,UAAAA,eAAe,EAAE,IAAI;AACrBC,UAAAA,qBAAqB,EAAE,KAAK;AAC5BC,UAAAA,OAAO,EAAE,KAAA;SACV,CAAA;AACH,OAAA;AACF,KAAA;;AAEA;AACA;AACA;AACA,IAAA,IAAIJ,WAAW,EAAE;MACf,MAAM/D,MAAM,GACVoE,eAAe,KAAK,MAAMlF,sBAAsB,CAAC6E,WAAW,CAAC,CAAC,CAAA;AAChE,MAAA,MAAM,CAAClB,KAAK,EAAEiC,WAAW,CAAC,GAAG,MAAM9B,WAAW,CAAC+B,cAAc,CAAC/E,MAAM,CAAC,CAAA;AAErE,MAAA,IAAI6C,KAAK,EAAE;AACTmB,QAAAA,mBAAmB,GAAG;AACpBvF,UAAAA,iBAAiB,EAAE,IAAI;UACvBiG,YAAY,EAAE7B,KAAK,CAAC8B,OAAO;AAC3BV,UAAAA,eAAe,EAAE,KAAK;AACtBC,UAAAA,qBAAqB,EAAE,KAAK;AAC5BC,UAAAA,OAAO,EAAE,IAAA;SACV,CAAA;QACDnB,WAAW,CAACI,sBAAsB,EAAE,CAAA;AACtC,OAAC,MAAM;AACL;AACA,QAAA,MAAM4B,iBAAiB,GAAGH,oBAAoB,CAAC7E,MAAM,CAAC,CAAA;AACtDgD,QAAAA,WAAW,CAACC,eAAe,CAAC+B,iBAAiB,CAAC,CAAA;AAE9CX,QAAAA,IAAI,GAAGS,WAAW,CAAA;AAClBd,QAAAA,mBAAmB,GAAG;AACpBvF,UAAAA,iBAAiB,EAAEuG,iBAAiB;AACpCf,UAAAA,eAAe,EAAE,IAAI;AACrBC,UAAAA,qBAAqB,EAAE,KAAK;AAC5BC,UAAAA,OAAO,EAAE,KAAA;SACV,CAAA;AACH,OAAA;AACF,KAAA;IAEA,OAAO;MAAEH,mBAAmB;AAAEK,MAAAA,IAAAA;KAAM,CAAA;AACtC,GAAA;EA4BA,OAAOY,UAAUA,CAACC,YAAY,EAAE;IAC9BlC,WAAW,CAACI,sBAAsB,EAAE,CAAA;IACpC,IAAIJ,WAAW,CAACnB,WAAW,EAAE;AAC3BmB,MAAAA,WAAW,CAACmC,WAAW,CAACD,YAAY,CAAC,CAAA;AACvC,KAAC,MAAM;AACL,MAAA,IAAIA,YAAY,EAAElC,WAAW,CAACoC,oBAAoB,CAACF,YAAY,CAAC,CAAC,KAC5DlC,WAAW,CAACqC,0BAA0B,EAAE,CAAA;AAC/C,KAAA;AACF,GAAA;EAEA,OAAOC,oBAAoBA,CAACnD,QAAQ,EAAE;AACpC,IAAA,IAAI,OAAOZ,MAAM,IAAI,WAAW,EAAE;MAChC,IAAIgE,GAAG,GAAG,GAAG,CAAA;AACb,MAAA,IAAIpD,QAAQ,EAAE;QACZ,MAAM;UAAEqD,MAAM;AAAEC,UAAAA,IAAAA;AAAK,SAAC,GAAGtD,QAAQ,CAAA;QACjCoD,GAAG,GAAGC,MAAM,GAAI,CAAA,EAAED,GAAI,CAAEC,EAAAA,MAAO,CAAC,CAAA,GAAGD,GAAG,CAAA;QACtCA,GAAG,GAAGE,IAAI,GAAI,CAAA,EAAEF,GAAI,CAAEE,EAAAA,IAAK,CAAC,CAAA,GAAGF,GAAG,CAAA;AACpC,OAAA;AACAhE,MAAAA,MAAM,CAACY,QAAQ,CAACuD,IAAI,GAAGH,GAAG,CAAA;AAC5B,KAAA;AACF,GAAA;EAEA,aAAaF,0BAA0BA,CAACH,YAAY,EAAE;IACpD,IAAIlC,WAAW,CAACnB,WAAW,EAAE;MAC3B,MAAMmB,WAAW,CAACmC,WAAW,EAAE,CAAA;MAC/B,MAAMnC,WAAW,CAAC2C,UAAU,EAAE,CAAA;AAChC,KAAC,MAAM;AACL;AACA,MAAA,IAAIJ,GAAG,GAAGvC,WAAW,CAAC4C,WAAW,CAAA;MACjC,IAAI,OAAOV,YAAY,KAAK,QAAQ,EAClCK,GAAG,GAAI,CAAEA,EAAAA,GAAI,CAAgBL,cAAAA,EAAAA,YAAa,CAAC,CAAA,CAAA;AAC7C,MAAA,IACE,OAAO/C,QAAQ,KAAK,WAAW,IAC/B+C,YAAY,KAAKlC,WAAW,CAAC4C,WAAW,EAExCzD,QAAQ,CAAC0D,OAAO,CAACN,GAAG,CAAC,CAAA;AACzB,KAAA;AACF,GAAA;EAEA,OAAOO,gCAAgCA,CAACC,YAAY,EAAE;AACpD,IAAA,IAAIR,GAAG,GAAGvC,WAAW,CAACgD,mBAAmB,CAAA;IACzC,IAAID,YAAY,KAAKR,GAAG,EAAE,OAAA;IAE1B,IAAI,OAAOQ,YAAY,KAAK,QAAQ,EAClCR,GAAG,GAAI,CAAEA,EAAAA,GAAI,CAAgBQ,cAAAA,EAAAA,YAAa,CAAC,CAAA,CAAA;IAC7C,IAAI,OAAO5D,QAAQ,KAAK,WAAW,EAAEA,QAAQ,CAACuD,IAAI,GAAGH,GAAG,CAAA;AAC1D,GAAA;EAEA,OAAOH,oBAAoBA,CAACF,YAAY,EAAE;AACxC,IAAA,IAAI,OAAOA,YAAY,KAAK,QAAQ,EAAE;MACpC,IAAI,OAAO/C,QAAQ,KAAK,WAAW,EAAEZ,MAAM,CAACY,QAAQ,CAACuD,IAAI,GAAGR,YAAY,CAAA;AAC1E,KAAC,MAAMlC,WAAW,CAACsC,oBAAoB,EAAE,CAAA;AAC3C,GAAA;EAEA,aAAaK,UAAUA,CAACM,WAAW,EAAE;AACnC,IAAA,MAAMC,WAAW,GAAG,MAAMzD,iBAAiB,CAACV,iBAAiB,CAAC,CAAA;IAC9DmE,WAAW,CAACC,cAAc,CAAC;AACzB5D,MAAAA,KAAK,EAAE,QAAQ;AACfD,MAAAA,aAAa,EAAE,UAAU;AACzBJ,MAAAA,YAAY,EAAE+D,WAAW,IAAI1E,MAAM,CAACY,QAAQ,CAACC,QAAQ,EAAA;AACvD,KAAC,CAAC,CAAA;AACJ,GAAA;EAEA,OAAOgE,wBAAwBA,GAAG;IAChC,MAAMC,MAAM,GAAG,IAAIC,eAAe,CAAC/E,MAAM,CAACY,QAAQ,CAACqD,MAAM,CAAC,CAAA;AAC1D,IAAA,IAAIa,MAAM,CAACE,GAAG,CAAC,eAAe,CAAC,IAAIF,MAAM,CAACE,GAAG,CAAC,eAAe,CAAC,EAAE;AAC9DF,MAAAA,MAAM,CAACG,MAAM,CAAC,eAAe,CAAC,CAAA;AAC9BH,MAAAA,MAAM,CAACG,MAAM,CAAC,eAAe,CAAC,CAAA;MAC9BjF,MAAM,CAACY,QAAQ,GAAI,CAAA,EAAEZ,MAAM,CAACY,QAAQ,CAACsE,QAAS,CAAA,EAC5CJ,MAAM,CAACjE,QAAQ,EAAE,GAAI,CAAA,CAAA,EAAGiE,MAAO,CAAC,CAAA,GAAG,EACpC,CAAC,CAAA,CAAA;AACJ,KAAA;AACF,GAAA;EAEA,aAAalB,WAAWA,CAACD,YAAY,EAAE;AACrC,IAAA,MAAMwB,KAAK,CACR,CAAA,EAAE1D,WAAW,CAAC2D,OAAQ,gDAA+C,EACtE;AACE5C,MAAAA,WAAW,EAAE,SAAA;AACf,KAAC,CACF,CAAA;AACD,IAAA,IAAImB,YAAY,EAAE;MAChB3D,MAAM,CAACY,QAAQ,GAAG+C,YAAY,CAAA;AAChC,KAAC,MAAM;AACL;AACA;MACAlC,WAAW,CAACoD,wBAAwB,EAAE,CAAA;AACxC,KAAA;AACF,GAAA;EAEA,aAAaQ,8BAA8BA,CAACC,aAAa,EAAE;AACzD,IAAA,MAAM,CAAChE,KAAK,EAAEiE,QAAQ,CAAC,GAAG,MAAMtC,EAAE,CAChCkC,KAAK,CAAE,CAAE1D,EAAAA,WAAW,CAAC2D,OAAQ,0CAAyC,EAAE;AACtEI,MAAAA,MAAM,EAAE,MAAM;AACdC,MAAAA,OAAO,EAAE;AACPC,QAAAA,MAAM,EAAE,kBAAkB;AAC1B,QAAA,cAAc,EAAE,kBAAA;OACjB;AACDC,MAAAA,IAAI,EAAEC,IAAI,CAACC,SAAS,CAAC;QACnBP,aAAa,EAAEnG,kBAAkB,CAACmG,aAAa,CAAA;OAChD,CAAA;AACH,KAAC,CAAC,CACH,CAAA;IACD,IAAIhE,KAAK,EAAE,OAAO,CAAC;AAAE8B,MAAAA,OAAO,EAAE,6BAAA;AAA8B,KAAC,CAAC,CAAA;IAC9D,IAAImC,QAAQ,CAACO,EAAE,EAAE;AACf,MAAA,MAAM,CAACC,UAAU,EAAEJ,IAAI,CAAC,GAAG,MAAM1C,EAAE,CAACsC,QAAQ,CAACS,IAAI,EAAE,CAAC,CAAA;AACpD,MAAA,IAAID,UAAU,EAAE,OAAO,CAACA,UAAU,CAAC,CAAA;MAEnC,MAAM;QAAEE,WAAW;AAAEC,QAAAA,eAAe,GAAG,EAAA;AAAG,OAAC,GAAGP,IAAI,CAAA;MAClD,IAAIM,WAAW,KAAK,CAAC,EAAE;AACrB,QAAA,OAAO,CACL;AAAE7C,UAAAA,OAAO,EAAE,2BAA2B;AAAE+C,UAAAA,IAAI,EAAED,eAAAA;AAAgB,SAAC,CAChE,CAAA;AACH,OAAA;AACA,MAAA,IAAIA,eAAe,CAACjE,MAAM,GAAG,CAAC,EAAE;AAC9B,QAAA,IAAI3E,YAAY,CAAA;AAChB4I,QAAAA,eAAe,CAAC7D,OAAO,CAAC+D,IAAI,IAAI;UAC9B,IAAIA,IAAI,CAACC,GAAG,KAAK,+BAA+B,EAC9C/I,YAAY,GAAG8I,IAAI,CAACE,KAAK,CAAA;AAC7B,SAAC,CAAC,CAAA;QACF,IAAI,CAAChJ,YAAY,EAAE;AACjB,UAAA,OAAO,CACL;AACE8F,YAAAA,OAAO,EACL,iEAAA;AACJ,WAAC,CACF,CAAA;AACH,SAAA;AACA,QAAA,OAAO,CAACmD,SAAS,EAAEjJ,YAAY,CAAC,CAAA;AAClC,OAAC,MAAM;AACL,QAAA,OAAO,CACL;AACE8F,UAAAA,OAAO,EACL,iEAAA;AACJ,SAAC,CACF,CAAA;AACH,OAAA;AACF,KAAC,MAAM;AACL,MAAA,OAAO,CACL;QACEA,OAAO,EAAG,4BAA2BmC,QAAQ,CAACiB,MAAO,CAAGjB,CAAAA,EAAAA,QAAQ,CAACkB,UAAW,CAAA,CAAA;AAC9E,OAAC,CACF,CAAA;AACH,KAAA;AACF,GAAA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACF,CAAA;AA7TahF,WAAW,CACf2D,OAAO,GAAGrH,OAAO,CAACE,GAAG,sBAAC;AADlBwD,WAAW,CAEfnB,WAAW,GAChBH,OAAO,CAACC,GAAG,CAACC,QAAQ,KAAK,aAAa,GAClCC,WAAW,KAAK,MAAM,4BACtBP,OAAO,CAACO,WAAW,KAAK,MAAM,CAAA;AALzBmB,WAAW,CAMf4C,WAAW,GAAG,gBAAgB,CAAA;AAN1B5C,WAAW,CAOfgD,mBAAmB,GAAG,wBAAwB,CAAA;AAP1ChD,WAAW,CAwIf+B,cAAc,GAAG,MAAM/E,MAAM,IAAI;AACtC,EAAA,IAAIiI,SAAS;IACXC,WAAW;IACX7D,IAAI,GAAG,EAAE;IACT8D,YAAY,CAAA;AAEd,EAAA,CAACF,SAAS,EAAE5D,IAAI,CAAC,GAAG,MAAMG,EAAE,CAACxE,MAAM,CAACoI,QAAQ,CAACC,KAAK,CAACC,UAAU,EAAE,CAAC,CAAA;AAChE,EAAA,IAAIjE,IAAI,IAAIA,IAAI,CAAC1E,EAAE,EAAE;AACnB,IAAA,CAACuI,WAAW,EAAEC,YAAY,CAAC,GAAG,MAAM3D,EAAE,CACpCxE,MAAM,CAACoI,QAAQ,CAACC,KAAK,CAACE,aAAa,CAAC;MAClCC,MAAM,EAAEnE,IAAI,CAAC1E,EAAE;AACf8I,MAAAA,gBAAgB,EAAE,IAAI;AACtBC,MAAAA,WAAW,EAAE;AAAEC,QAAAA,QAAQ,EAAE,GAAA;AAAI,OAAA;AAC/B,KAAC,CAAC,CACH,CAAA;AACD;AACA;AACA,IAAA,IAAIR,YAAY,IAAIA,YAAY,CAACS,KAAK,EAAEvE,IAAI,CAACwE,MAAM,GAAGV,YAAY,CAACS,KAAK,CAAA;;AAExE;AACA;AACA,IAAA,IAAIV,WAAW,EAAEtF,OAAO,CAACkG,GAAG,CAACZ,WAAW,CAAC,CAAA;AAC3C,GAAA;AACA,EAAA,OAAO,CAACD,SAAS,EAAE5D,IAAI,CAAC,CAAA;AAC1B,CAAC;;ACtJU0E,MAAAA,UAAU,GAAG,CACxBC,SAAS,CAACC,UAAU,EAAEC,aAAa,CAAC,EACpCF,SAAS,CAACG,WAAW,EAAEC,cAAc,CAAC,EACtCJ,SAAS,CAACK,aAAa,EAAEC,gBAAgB,CAAC,EAC1CN,SAAS,CAACO,wBAAwB,EAAEC,gCAAgC,CAAC,EACtE;AAEM,UAAUC,uBAAuBA,CAACC,MAAM,EAAE;AAAA,EAAA,IAAAC,UAAA,CAAA;EAC/C,MAAM;IACJC,KAAK;IACLC,YAAY;AACZC,IAAAA,MAAM,EAAE;AAAE1L,MAAAA,mBAAAA;KAAqB;AAC/B2L,IAAAA,WAAAA;AACF,GAAC,GAAGL,MAAM,CAAA;AACV,EAAA,IAAIM,YAAY,GAAG,MAAMC,MAAM,CAACC,yBAAyB,CAAC,CAAA;;AAE1D;EACA,MAAMC,SAAS,GAAGC,WAAW,CAAC,MAAMH,MAAM,CAACI,mBAAmB,CAAC,CAAC,CAAA;EAChE,MAAMxD,aAAa,GAAGsD,SAAS,CAACtD,aAAa,IAAIsD,SAAS,CAACG,aAAa,CAAA;;AAExE;EACA,MAAM;AAAET,IAAAA,YAAY,EAAEU,SAAAA;GAAW,GAAIR,WAAW,IAAIA,WAAW,CAACS,KAAK,IAAK,EAAE,CAAA;EAC5E,MAAM;AAAEX,IAAAA,YAAY,EAAEY,eAAAA;GAAiB,GACpCb,KAAK,IACJzL,sBAAsB,CAACC,mBAAmB,EAAEwL,KAAK,KAALA,IAAAA,IAAAA,KAAK,KAAAD,KAAAA,CAAAA,GAAAA,KAAAA,CAAAA,GAAAA,CAAAA,UAAA,GAALC,KAAK,CAAEc,GAAG,MAAA,IAAA,IAAAf,UAAA,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAVA,UAAA,CAAYtL,aAAa,CAAC,IACxE,EAAE,CAAA;;AAEJ;AACA;AACA,EAAA,MAAMsM,mBAAmB,GAAG,CAC1B,IAAKC,KAAK,CAACC,OAAO,CAACJ,eAAe,CAAC,IAAIA,eAAe,IAAK,EAAE,CAAC,EAC9D,IAAKG,KAAK,CAACC,OAAO,CAACN,SAAS,CAAC,IAAIA,SAAS,IAAK,EAAE,CAAC,EAClD,IAAKK,KAAK,CAACC,OAAO,CAAChB,YAAY,CAAC,IAAIA,YAAY,IAAK,EAAE,CAAC,CACzD,CAAA;AACD,EAAA,MAAMiB,kBAAkB,GAAG,CAAC,CAACL,eAAe,IAAI,CAAC,CAACF,SAAS,IAAI,CAAC,CAACV,YAAY,CAAA;EAE7E,IAAI,CAACG,YAAY,EAAE;AACjB;AACA;AACA,IAAA,IAAIc,kBAAkB,EAAE;AACtB;AACAd,MAAAA,YAAY,GAAG,MAAMe,IAAI,CAACzB,gBAAgB,EAAE;AAAEzC,QAAAA,aAAAA;AAAc,OAAC,CAAC,CAAA;AAChE,KAAA;AACA;SACK,MAAMmE,GAAG,CAAC;AAAEC,MAAAA,IAAI,EAAE5B,aAAa;AAAExC,MAAAA,aAAAA;AAAc,KAAC,CAAC,CAAA;AACxD,GAAA;AAEA,EAAA,IAAIiE,kBAAkB,EAAE;AACtB;AACA;AACA,IAAA,IAAI,CAACd,YAAY,IAAI,CAACnD,aAAa,EAAE;MACnC7D,WAAW,CAACqC,0BAA0B,CAACqE,MAAM,CAACvH,QAAQ,CAACsE,QAAQ,CAAC,CAAA;AAClE,KAAC,MAAM,IAAIkE,mBAAmB,CAACnH,MAAM,GAAG,CAAC,EAAE;MACzC,MAAM0H,UAAU,GAAG,MAAMjB,MAAM,CAACkB,gBAAgB,EAAE,IAAI,CAAC,CAAA;AACvD,MAAA,MAAMC,UAAU,GAAGC,cAAc,CAACH,UAAU,EAAEP,mBAAmB,CAAC,CAAA;AAElE,MAAA,IAAI,CAACS,UAAU,EACbpI,WAAW,CAAC8C,gCAAgC,CAAC4D,MAAM,CAACvH,QAAQ,CAACsE,QAAQ,CAAC,CAAA;AAC1E,KAAA;AACF,GAAA;AACF,CAAA;AAEA,UAAU6C,gBAAgBA,CAAC;AAAEzC,EAAAA,aAAAA;AAAc,CAAC,EAAE;AAC5C;AACA,EAAA,IAAIpI,iBAAiB,GAAGuE,WAAW,CAACG,oBAAoB,EAAE,CAAA;AAE1D,EAAA,IAAI0D,aAAa,IAAIpI,iBAAiB,CAACI,YAAY,EAAE;AACnD;AACA;AACA;AACA,IAAA,MAAMmM,GAAG,CAAC;AACRC,MAAAA,IAAI,EAAE1B,wBAAwB;AAC9BvF,MAAAA,mBAAmB,EAAE;AACnBsH,QAAAA,SAAS,EAAE,IAAA;AACb,OAAA;AACF,KAAC,CAAC,CAAA;AACF;AACA;AACA,IAAA,MAAM,CAACzI,KAAK,EAAEhE,YAAY,CAAC,GACzB,MAAMmE,WAAW,CAAC4D,8BAA8B,CAACC,aAAa,CAAC,CAAA;AACjE,IAAA,IAAIhI,YAAY,EAAE;AAChB;MACAmE,WAAW,CAACC,eAAe,CAAC;AAC1BlE,QAAAA,qBAAqB,EAAE8H,aAAa;AACpChI,QAAAA,YAAAA;AACF,OAAC,CAAC,CAAA;AACFJ,MAAAA,iBAAiB,GAAGuE,WAAW,CAACG,oBAAoB,EAAE,CAAA;AACxD,KAAA;;AAEA;IACA,IAAI1E,iBAAiB,CAACI,YAAY,EAChC,MAAMkM,IAAI,CAAC7B,aAAa,EAAE;AAAEzK,MAAAA,iBAAAA;KAAmB,CAAC,CAAC,KAC9C,IAAIoE,KAAK,EACZ,MAAMmI,GAAG,CAAC;AACRC,MAAAA,IAAI,EAAE1B,wBAAwB;AAC9BvF,MAAAA,mBAAmB,EAAE;AACnBG,QAAAA,OAAO,EAAE,IAAI;AACbO,QAAAA,YAAY,EACV,CAAA7B,KAAK,aAALA,KAAK,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAALA,KAAK,CAAE8B,OAAO,KACb9B,KAAK,IAAI,UAAU,IAAIA,KAAK,IAAIA,KAAK,CAACT,QAAQ,EAAA;AACnD,OAAA;AACF,KAAC,CAAC,CAAA;AACN,GAAA;;AAEA;AACA,EAAA,OAAO,MAAM6H,MAAM,CAACC,yBAAyB,CAAC,CAAA;AAChD,CAAA;AAEA,UAAUhB,aAAaA,CAACQ,MAAM,GAAG,EAAE,EAAE;EACnC,MAAM;IAAEvK,QAAQ;IAAEC,QAAQ;AAAEX,IAAAA,iBAAAA;AAAkB,GAAC,GAAGiL,MAAM,CAAA;;AAExD;AACA;AACA,EAAA,IAAIA,MAAM,CAACuB,IAAI,KAAKhC,UAAU,IAAIjG,WAAW,CAACnB,WAAW,EACvDmB,WAAW,CAACqC,0BAA0B,EAAE,CAAA;EAE1C,MAAM;IAAErB,mBAAmB;AAAEK,IAAAA,IAAAA;AAAK,GAAC,GAAG,MAAMrB,WAAW,CAACc,SAAS,CAAC;IAChE3E,QAAQ;IACRC,QAAQ;AACRX,IAAAA,iBAAAA;AACF,GAAC,CAAC,CAAA;AAEF,EAAA,MAAMuM,GAAG,CAAC;AACRC,IAAAA,IAAI,EAAE1B,wBAAwB;IAC9BvF,mBAAmB;AACnBK,IAAAA,IAAAA;AACF,GAAC,CAAC,CAAA;AACJ,CAAA;AACA,MAAMkH,kBAAkB,GAAGC,IAAI,IAAI;AACjC;AACA5I,EAAAA,OAAO,CAACkG,GAAG,CAAC0C,IAAI,CAAC,CAAA;AACjB,EAAA,MAAMC,YAAY,GAAG,GAAG,GAAGD,IAAI,CAACE,KAAK,CAAC,GAAG,CAAC,CAACC,MAAM,CAAC,CAAC,CAAC,CAACC,IAAI,CAAC,GAAG,CAAC,CAAA;AAC9D;AACAhJ,EAAAA,OAAO,CAACkG,GAAG,CAAC2C,YAAY,CAAC,CAAA;AACzB,EAAA,OAAOA,YAAY,CAAA;AACrB,CAAC,CAAA;AAED,UAAUjC,gCAAgCA,GAAG;AAC3C,EAAA,MAAMqC,UAAU,GAAG,MAAM5B,MAAM,CAACC,yBAAyB,CAAC,CAAA;EAC1D,MAAM;AAAEhI,IAAAA,YAAY,EAAEgD,YAAY;AAAE4G,IAAAA,SAAS,EAAEC,iBAAAA;GAAmB,GAChE3B,WAAW,CAAC,MAAMH,MAAM,CAACI,mBAAmB,CAAC,CAAC,CAAA;EAEhD,IAAIwB,UAAU,IAAIE,iBAAiB,IAAI,OAAOxK,MAAM,IAAI,WAAW,EAAE;AACnE,IAAA,MAAMiK,IAAI,GAAGD,kBAAkB,CAACQ,iBAAiB,CAAC,CAAA;AAClD;AACA;AACAxK,IAAAA,MAAM,CAACY,QAAQ,CAACuD,IAAI,GAAG8F,IAAI,CAAA;AAC3B;AACF,GAAC,MAAM,IAAIK,UAAU,IAAI3G,YAAY,EAAE;AACrC,IAAA,MAAM8F,GAAG,CAACgB,QAAQ,CAAC9G,YAAY,CAAC,CAAC,CAAA;AACnC,GAAA;AACF,CAAA;AAEA,UAAUkE,cAAcA,CAAC;AAAElE,EAAAA,YAAAA;AAAa,CAAC,EAAE;AACzC,EAAA,MAAM8F,GAAG,CAAC;AACRC,IAAAA,IAAI,EAAE1B,wBAAwB;AAC9BlF,IAAAA,IAAI,EAAE,IAAA;AACR,GAAC,CAAC,CAAA;AACF,EAAA,MAAMrB,WAAW,CAACiC,UAAU,CAACC,YAAY,CAAC,CAAA;AAC5C,CAAA;AAEO,UAAU+G,oBAAoBA,GAAG;EACtC,MAAMxN,iBAAiB,GAAG,MAAMwL,MAAM,CAACiC,uBAAuB,EAAE,IAAI,CAAC,CAAA;EACrE,IAAIC,MAAM,CAAC7I,IAAI,CAAC7E,iBAAiB,CAAC,CAAC+E,MAAM,GAAG,CAAC,EAAE;AAC7C,IAAA,MAAMxD,MAAM,GAAG,MAAMd,sBAAsB,CAACT,iBAAiB,CAAC,CAAA;IAC9D,MAAMuB,MAAM,CAACoM,YAAY,EAAE,CAAA;AAE3B,IAAA,MAAMpB,GAAG,CAAC;AACRC,MAAAA,IAAI,EAAE1B,wBAAwB;AAC9BvF,MAAAA,mBAAmB,EAAE;QACnBvF,iBAAiB,EAAEoG,oBAAoB,CAAC7E,MAAM,CAAA;AAChD,OAAA;AACF,KAAC,CAAC,CAAA;AACJ,GAAA;AACF;;;;"}
|
|
1
|
+
{"version":3,"file":"login-2427614b.js","sources":["../src/routing/util/find-contenttype-mapping.ts","../src/user/transformations/mapClientCredentials.js","../src/user/util/ContensisManagementApi.js","../src/user/util/CookieHelper.class.ts","../src/user/util/OidcUserManager.ts","../src/user/util/LoginHelper.class.js","../src/user/redux/sagas/login.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 const { Client } = await import('contensis-management-api');\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 JSCookie from 'js-cookie';\n\nconst COOKIE_VALID_DAYS = 1; // 0 = Session cookie\n\n// Override the default js-cookie conversion / encoding\n// methods so the written values work with Contensis sites\nconst Cookies = JSCookie.withConverter({\n read: value => decodeURIComponent(value),\n write: value => encodeURIComponent(value),\n});\n\nexport class CookieHelper {\n static GetCookie(name) {\n const cookie = Cookies.get(name);\n if (typeof cookie === 'undefined') {\n return null;\n }\n return cookie;\n }\n\n static SetCookie(name, value, maxAgeDays = COOKIE_VALID_DAYS) {\n if (maxAgeDays === 0) Cookies.set(name, value);\n else Cookies.set(name, value, { expires: maxAgeDays });\n }\n\n static DeleteCookie(name) {\n Cookies.remove(name);\n }\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 { getManagementApiClient } from './ContensisManagementApi';\nimport { to } from 'await-to-js';\n\nimport { CookieHelper } from './CookieHelper.class';\n\nimport mapClientCredentials from '../transformations/mapClientCredentials';\nimport { createUserManager, userManagerConfig } from './OidcUserManager';\n\nconst LOGIN_COOKIE = 'ContensisCMSUserName';\nconst REFRESH_TOKEN_COOKIE = 'RefreshToken';\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 static SetLoginCookies({ contensisClassicToken, refreshToken }) {\n console.info(\n 'SetLoginCookies:',\n LOGIN_COOKIE,\n contensisClassicToken,\n REFRESH_TOKEN_COOKIE,\n refreshToken\n );\n if (contensisClassicToken)\n CookieHelper.SetCookie(LOGIN_COOKIE, contensisClassicToken);\n if (refreshToken)\n CookieHelper.SetCookie(REFRESH_TOKEN_COOKIE, refreshToken);\n }\n\n static GetCachedCredentials() {\n return {\n bearerToken: null,\n bearerTokenExpiryDate: null,\n refreshToken: CookieHelper.GetCookie(REFRESH_TOKEN_COOKIE),\n refreshTokenExpiryDate: null,\n contensisClassicToken: CookieHelper.GetCookie(LOGIN_COOKIE),\n };\n }\n\n static ClearCachedCredentials() {\n CookieHelper.DeleteCookie(LOGIN_COOKIE);\n CookieHelper.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 static 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 LoginHelper.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 LoginHelper.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 LoginHelper.ClearCachedCredentials();\n } else {\n // Ensure we get latest refreshToken and contensisClassicToken from the latest client\n const latestCredentials = mapClientCredentials(client);\n LoginHelper.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 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 LogoutUser(redirectPath) {\n LoginHelper.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 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 (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 ClientRedirectToAccessDeniedPage(originalPath) {\n let url = LoginHelper.ACCESS_DENIED_ROUTE;\n if (originalPath === url) return;\n\n if (typeof originalPath === 'string')\n url = `${url}?original_uri=${originalPath}`;\n if (typeof location !== 'undefined') location.href = url;\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 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 entry,\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 // If routeRequiresLogin do a blocking call that returns userLoggedIn\n userLoggedIn = yield call(validateUserSaga, { securityToken });\n }\n // otherwise do a non blocking put to handle validation in the background\n else yield put({ type: VALIDATE_USER, 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\nfunction* validateUserSaga({ securityToken }) {\n // Check for refreshToken in cookies\n let clientCredentials = LoginHelper.GetCachedCredentials();\n\n if (securityToken || clientCredentials.refreshToken) {\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 const [error, refreshToken] =\n yield LoginHelper.GetCredentialsForSecurityToken(securityToken);\n if (refreshToken) {\n // Set cookies and reload values\n LoginHelper.SetLoginCookies({\n contensisClassicToken: securityToken,\n refreshToken,\n });\n clientCredentials = LoginHelper.GetCachedCredentials();\n }\n\n // Log the user in if a refreshToken is found\n if (clientCredentials.refreshToken)\n yield call(loginUserSaga, { clientCredentials });\n else if (error)\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 // Tell any callers have we successfully logged in?\n return yield select(selectUserIsAuthenticated);\n}\n\nfunction* loginUserSaga(action = {}) {\n const { username, password, clientCredentials } = action;\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 LoginHelper.LoginUser({\n username,\n password,\n clientCredentials,\n });\n\n yield put({\n type: SET_AUTHENTICATION_STATE,\n authenticationState,\n user,\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 }) {\n yield put({\n type: SET_AUTHENTICATION_STATE,\n user: null,\n });\n yield LoginHelper.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"],"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","client","create","COOKIE_VALID_DAYS","Cookies","JSCookie","withConverter","read","value","decodeURIComponent","write","encodeURIComponent","CookieHelper","GetCookie","name","cookie","get","SetCookie","maxAgeDays","set","expires","DeleteCookie","remove","context","window","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","LOGIN_COOKIE","REFRESH_TOKEN_COOKIE","LoginHelper","SetLoginCookies","info","GetCachedCredentials","ClearCachedCredentials","localStorage","keys","i","length","key","startsWith","push","forEach","removeItem","LoginUser","credentials","authenticationState","isAuthenticated","isAuthenticationError","isError","transientClient","user","loginError","clientBearerToken","to","ensureBearerToken","errorMessage","message","includes","mapClientCredentials","userDetails","GetUserDetails","latestCredentials","LogoutUser","redirectPath","WsFedLogout","ClientRedirectToPath","ClientRedirectToSignInPage","ClientRedirectToHome","url","search","hash","href","WsFedLogin","LOGIN_ROUTE","replace","ClientRedirectToAccessDeniedPage","originalPath","ACCESS_DENIED_ROUTE","redirectUri","userManager","signinRedirect","RemoveSecurityTokenQuery","params","URLSearchParams","has","delete","pathname","fetch","CMS_URL","GetCredentialsForSecurityToken","securityToken","response","method","headers","Accept","body","JSON","stringify","ok","parseError","json","LogonResult","ApplicationData","data","item","Key","Value","undefined","status","statusText","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","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","isLoading","removeHostnamePart","path","relativePath","split","splice","join","isLoggedIn","ReturnURL","assetRedirectPath","setRoute","refreshSecurityToken","selectClientCredentials","Object","authenticate"],"mappings":"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"}
|
package/esm/redux.js
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import { n as navigation$2, v as version$1, G as GET_NODE_TREE, e as version$3 } from './version-
|
|
2
|
-
export { r as store } from './version-
|
|
3
|
-
import { E as routing$1, D as action, F as routing$2, G as routing$3 } from './selectors-
|
|
4
|
-
export { D as action, g as getIn, H as getJS } from './selectors-
|
|
5
|
-
import { v as version$2, n as navigation$3 } from './version-
|
|
6
|
-
export { c as convertSagaArray, b as injectReducer, i as injectRedux, d as injectSaga, u as useInjectRedux } from './version-
|
|
1
|
+
import { n as navigation$2, v as version$1, G as GET_NODE_TREE, e as version$3 } from './version-0160e6b9.js';
|
|
2
|
+
export { r as store } from './version-0160e6b9.js';
|
|
3
|
+
import { E as routing$1, D as action, F as routing$2, G as routing$3 } from './selectors-0b9508f4.js';
|
|
4
|
+
export { D as action, g as getIn, H as getJS } from './selectors-0b9508f4.js';
|
|
5
|
+
import { v as version$2, n as navigation$3 } from './version-cef1a76d.js';
|
|
6
|
+
export { c as convertSagaArray, b as injectReducer, i as injectRedux, d as injectSaga, u as useInjectRedux } from './version-cef1a76d.js';
|
|
7
7
|
import 'redux';
|
|
8
8
|
import 'redux-thunk';
|
|
9
9
|
import 'redux-saga';
|
package/esm/routing.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
export { F as actions, G as selectors, E as types } from './selectors-
|
|
2
|
-
export { R as RouteLoader } from './RouteLoader-
|
|
1
|
+
export { F as actions, G as selectors, E as types } from './selectors-0b9508f4.js';
|
|
2
|
+
export { R as RouteLoader } from './RouteLoader-46031747.js';
|
|
3
3
|
import 'jsonpath-mapper';
|
|
4
4
|
import 'query-string';
|
|
5
5
|
import 'react';
|
|
@@ -8,5 +8,5 @@ import 'react-hot-loader';
|
|
|
8
8
|
import 'react-router-dom';
|
|
9
9
|
import 'react-router-config';
|
|
10
10
|
import 'reselect';
|
|
11
|
-
import './ToJs-
|
|
11
|
+
import './ToJs-4a595f89.js';
|
|
12
12
|
//# sourceMappingURL=routing.js.map
|
|
@@ -111,18 +111,18 @@ const clearFilters$1 = filterKey => {
|
|
|
111
111
|
filterKey
|
|
112
112
|
};
|
|
113
113
|
};
|
|
114
|
-
const updatePageIndex$1 = (pageIndex,
|
|
114
|
+
const updatePageIndex$1 = (pageIndex, scrollToElement) => {
|
|
115
115
|
return {
|
|
116
116
|
type: UPDATE_PAGE_INDEX,
|
|
117
117
|
pageIndex,
|
|
118
|
-
|
|
118
|
+
scrollToElement
|
|
119
119
|
};
|
|
120
120
|
};
|
|
121
|
-
const updatePageSize$1 = (pageSize,
|
|
121
|
+
const updatePageSize$1 = (pageSize, scrollToElement) => {
|
|
122
122
|
return {
|
|
123
123
|
type: UPDATE_PAGE_SIZE,
|
|
124
124
|
pageSize,
|
|
125
|
-
|
|
125
|
+
scrollToElement
|
|
126
126
|
};
|
|
127
127
|
};
|
|
128
128
|
const updateCurrentFacet$1 = facet => {
|
|
@@ -143,13 +143,13 @@ const updateSearchTerm$1 = term => {
|
|
|
143
143
|
term
|
|
144
144
|
};
|
|
145
145
|
};
|
|
146
|
-
const updateSelectedFilters = (filter, key, isUnknownItem = false,
|
|
146
|
+
const updateSelectedFilters = (filter, key, isUnknownItem = false, scrollToElement) => {
|
|
147
147
|
return {
|
|
148
148
|
type: UPDATE_SELECTED_FILTERS,
|
|
149
149
|
filter,
|
|
150
150
|
key,
|
|
151
151
|
isUnknownItem,
|
|
152
|
-
|
|
152
|
+
scrollToElement
|
|
153
153
|
};
|
|
154
154
|
};
|
|
155
155
|
const updateSortOrder$1 = (orderBy, facet) => {
|
|
@@ -1528,8 +1528,16 @@ const debugExecuteSearch = (action, state) => {
|
|
|
1528
1528
|
console.log(stateParams, queryParams);
|
|
1529
1529
|
console.log('getSelectedFilters', getSelectedFilters(action.ogState || state, action.facet, action.context, 'js'), 'params', action.params);
|
|
1530
1530
|
};
|
|
1531
|
-
const
|
|
1532
|
-
if (typeof window !== 'undefined')
|
|
1531
|
+
const scrollTo = scrollToElement => {
|
|
1532
|
+
if (typeof window !== 'undefined') {
|
|
1533
|
+
if (typeof scrollToElement === 'number')
|
|
1534
|
+
// Used to be Y coordinate, deprecated, because it's not accessible
|
|
1535
|
+
console.warn('updatePageIndex arg2 needs string');else if (typeof scrollToElement === 'string') {
|
|
1536
|
+
/* Effectively simulates an anchor link. Needed for accessibility, as window.scrollTo
|
|
1537
|
+
does not change focus, only scrolls the screen */
|
|
1538
|
+
window.location.href = `${location.pathname}${location.search}#${scrollToElement}`;
|
|
1539
|
+
}
|
|
1540
|
+
}
|
|
1533
1541
|
};
|
|
1534
1542
|
|
|
1535
1543
|
// *** FILTER ITEM MAPPING ***
|
|
@@ -1909,34 +1917,34 @@ function* updatePageIndex(action) {
|
|
|
1909
1917
|
const {
|
|
1910
1918
|
pageIndex,
|
|
1911
1919
|
mappers,
|
|
1912
|
-
|
|
1920
|
+
scrollToElement
|
|
1913
1921
|
} = action;
|
|
1914
1922
|
const uri = yield buildUri({
|
|
1915
1923
|
pageIndex
|
|
1916
1924
|
}, mappers);
|
|
1917
1925
|
yield put(navigate(uri));
|
|
1918
|
-
if (typeof
|
|
1926
|
+
if (typeof scrollToElement !== 'undefined') scrollTo(scrollToElement);
|
|
1919
1927
|
}
|
|
1920
1928
|
function* updatePageSize(action) {
|
|
1921
1929
|
const {
|
|
1922
1930
|
pageSize,
|
|
1923
1931
|
mappers,
|
|
1924
|
-
|
|
1932
|
+
scrollToElement
|
|
1925
1933
|
} = action;
|
|
1926
1934
|
const uri = yield buildUri({
|
|
1927
1935
|
pageSize
|
|
1928
1936
|
}, mappers);
|
|
1929
1937
|
yield put(navigate(uri));
|
|
1930
|
-
if (typeof
|
|
1938
|
+
if (typeof scrollToElement !== 'undefined') scrollTo(scrollToElement);
|
|
1931
1939
|
}
|
|
1932
1940
|
function* applySearchFilter(action) {
|
|
1933
1941
|
const {
|
|
1934
1942
|
mappers,
|
|
1935
|
-
|
|
1943
|
+
scrollToElement
|
|
1936
1944
|
} = action;
|
|
1937
1945
|
const uri = yield buildUri({}, mappers);
|
|
1938
1946
|
yield put(navigate(uri));
|
|
1939
|
-
if (typeof
|
|
1947
|
+
if (typeof scrollToElement !== 'undefined') scrollTo(scrollToElement);
|
|
1940
1948
|
}
|
|
1941
1949
|
function* buildUri({
|
|
1942
1950
|
facet,
|
|
@@ -1972,4 +1980,4 @@ function* triggerSearchSsr(options) {
|
|
|
1972
1980
|
}
|
|
1973
1981
|
|
|
1974
1982
|
export { EXECUTE_SEARCH as $, clearFilters$1 as A, updateCurrentFacet$1 as B, updateCurrentTab$1 as C, updatePageIndex$1 as D, updatePageSize$1 as E, updateSearchTerm$1 as F, updateSelectedFilters as G, updateSortOrder$1 as H, selectListing as I, mapStateToSearchUri as J, Context as K, selectFacets as L, triggerSearch as M, getFilters as N, toArray as O, UPDATE_SELECTED_FILTERS as P, UPDATE_SEARCH_TERM as Q, UPDATE_PAGE_SIZE as R, UPDATE_PAGE_INDEX as S, SET_SEARCH_FILTERS as T, UPDATE_SORT_ORDER as U, SET_SEARCH_ENTRIES as V, SET_ROUTE_FILTERS as W, LOAD_FILTERS_COMPLETE as X, LOAD_FILTERS_ERROR as Y, LOAD_FILTERS as Z, EXECUTE_SEARCH_ERROR as _, customWhereExpressions as a, CLEAR_FILTERS as a0, APPLY_CONFIG as a1, actions as a2, selectors as a3, types as a4, expressions as a5, queries as a6, doSearch as a7, setRouteFilters as a8, searchSagas as a9, triggerListingSsr as aa, triggerMinilistSsr as ab, triggerSearchSsr as ac, routeParams as ad, getPageIndex as b, contentTypeIdExpression as c, defaultExpressions as d, getCurrentTab as e, filterExpressions as f, getCurrentFacet as g, getFacet as h, getTabFacets as i, getFacetsTotalCount as j, getFacetTitles as k, getFeaturedResults as l, getRenderableFilters as m, getIsLoading as n, orderByExpression as o, getPaging as p, getPageIsLoading as q, getResults as r, getSearchTerm as s, termExpressions as t, getSearchTotalCount as u, getSelectedFilters as v, getQueryParameter as w, getTabsAndFacets as x, getTotalCount as y, withMappers as z };
|
|
1975
|
-
//# sourceMappingURL=sagas-
|
|
1983
|
+
//# sourceMappingURL=sagas-933a8fc8.js.map
|