@zengenti/contensis-react-base 3.0.2-beta.23 → 3.0.2-beta.25
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-21a7d836.js → App-ad6f7fa7.js} +48 -21
- package/cjs/App-ad6f7fa7.js.map +1 -0
- package/cjs/{ContensisDeliveryApi-c079b03a.js → ContensisDeliveryApi-98c0016f.js} +57 -34
- package/cjs/ContensisDeliveryApi-98c0016f.js.map +1 -0
- package/cjs/CookieConstants-000427db.js +10 -0
- package/cjs/CookieConstants-000427db.js.map +1 -0
- package/cjs/CookieHelper.class-daeb09dd.js +52 -0
- package/cjs/CookieHelper.class-daeb09dd.js.map +1 -0
- package/cjs/{RouteLoader-7f0d107a.js → RouteLoader-005d7f4e.js} +9 -5
- package/cjs/RouteLoader-005d7f4e.js.map +1 -0
- package/cjs/{ToJs-6e9cfa69.js → ToJs-5169fe56.js} +2 -2
- package/cjs/{ToJs-6e9cfa69.js.map → ToJs-5169fe56.js.map} +1 -1
- package/cjs/client.js +11 -10
- package/cjs/client.js.map +1 -1
- package/cjs/contensis-react-base.js +17 -341
- package/cjs/contensis-react-base.js.map +1 -1
- package/cjs/{login-2a6b5be0.js → login-c94a3369.js} +86 -80
- package/cjs/login-c94a3369.js.map +1 -0
- package/cjs/redux.js +3 -3
- package/cjs/routing.js +5 -3
- package/cjs/routing.js.map +1 -1
- package/cjs/{selectors-bcca60f4.js → selectors-bb991331.js} +4 -9
- package/cjs/selectors-bb991331.js.map +1 -0
- package/cjs/user.js +30 -15
- package/cjs/user.js.map +1 -1
- package/cjs/util.js +7 -3
- package/cjs/util.js.map +1 -1
- package/cjs/{version-4077e706.js → version-153ec9ef.js} +2 -2
- package/cjs/{version-4077e706.js.map → version-153ec9ef.js.map} +1 -1
- package/cjs/{version-fe28099e.js → version-963a7634.js} +3 -3
- package/cjs/{version-fe28099e.js.map → version-963a7634.js.map} +1 -1
- package/esm/{App-2af18a99.js → App-f7ef3cb9.js} +47 -21
- package/esm/App-f7ef3cb9.js.map +1 -0
- package/esm/{ContensisDeliveryApi-5660ee0e.js → ContensisDeliveryApi-137270c0.js} +56 -35
- package/esm/ContensisDeliveryApi-137270c0.js.map +1 -0
- package/esm/CookieConstants-3d3b6531.js +6 -0
- package/esm/CookieConstants-3d3b6531.js.map +1 -0
- package/esm/CookieHelper.class-4d6ee27b.js +49 -0
- package/esm/CookieHelper.class-4d6ee27b.js.map +1 -0
- package/esm/{RouteLoader-6eac364e.js → RouteLoader-d36840dd.js} +9 -5
- package/esm/RouteLoader-d36840dd.js.map +1 -0
- package/esm/{ToJs-9b30636a.js → ToJs-e1af7030.js} +2 -2
- package/esm/{ToJs-9b30636a.js.map → ToJs-e1af7030.js.map} +1 -1
- package/esm/client.js +12 -11
- package/esm/client.js.map +1 -1
- package/esm/contensis-react-base.js +17 -342
- package/esm/contensis-react-base.js.map +1 -1
- package/esm/{login-71ff3fcb.js → login-950e0b92.js} +79 -72
- package/esm/login-950e0b92.js.map +1 -0
- package/esm/redux.js +6 -6
- package/esm/routing.js +5 -3
- package/esm/routing.js.map +1 -1
- package/esm/{selectors-74de49a3.js → selectors-1a3c1725.js} +4 -9
- package/esm/selectors-1a3c1725.js.map +1 -0
- package/esm/user.js +27 -16
- package/esm/user.js.map +1 -1
- package/esm/util.js +5 -3
- package/esm/util.js.map +1 -1
- package/esm/{version-ef107106.js → version-6cc0418c.js} +2 -2
- package/esm/{version-ef107106.js.map → version-6cc0418c.js.map} +1 -1
- package/esm/{version-b15807c5.js → version-ec722079.js} +3 -3
- package/esm/{version-b15807c5.js.map → version-ec722079.js.map} +1 -1
- package/models/routing/redux/actions.d.ts +10 -6
- package/models/routing/redux/types.d.ts +0 -1
- package/models/routing/routes.d.ts +3 -0
- package/models/search/models/Queries.d.ts +8 -10
- package/models/search/models/Search.d.ts +24 -24
- package/models/search/models/SearchActions.d.ts +33 -33
- package/models/search/models/SearchState.d.ts +11 -11
- package/models/search/models/SearchUtil.d.ts +1 -1
- package/models/search/models/WithSearch.d.ts +1 -1
- package/models/search/redux/actions.d.ts +4 -4
- package/models/search/redux/selectors.d.ts +27 -27
- package/models/search/redux/util.d.ts +1 -1
- package/models/search/search/expressions.d.ts +4 -4
- package/models/search/search/util.d.ts +2 -2
- package/models/search/transformations/state-to-queryparams.mapper.d.ts +1 -1
- package/models/user/hocs/withLogin.d.ts +5 -5
- package/models/user/redux/actions.d.ts +2 -2
- package/models/user/redux/sagas/login.d.ts +9 -8
- package/models/user/util/CookieConstants.d.ts +7 -0
- package/models/user/util/CookieHelper.class.d.ts +15 -3
- package/models/user/util/LoginHelper.class.d.ts +26 -23
- package/models/util/ContensisDeliveryApi.d.ts +21 -14
- package/models/util/index.d.ts +1 -1
- package/package.json +4 -5
- package/cjs/App-21a7d836.js.map +0 -1
- package/cjs/ContensisDeliveryApi-c079b03a.js.map +0 -1
- package/cjs/RouteLoader-7f0d107a.js.map +0 -1
- package/cjs/login-2a6b5be0.js.map +0 -1
- package/cjs/selectors-bcca60f4.js.map +0 -1
- package/esm/App-2af18a99.js.map +0 -1
- package/esm/ContensisDeliveryApi-5660ee0e.js.map +0 -1
- package/esm/RouteLoader-6eac364e.js.map +0 -1
- package/esm/login-71ff3fcb.js.map +0 -1
- package/esm/selectors-74de49a3.js.map +0 -1
|
@@ -1,10 +1,10 @@
|
|
|
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-e1af7030.js';
|
|
4
|
+
import { q as queryParams, o as selectCurrentSearch, p as setRoute } from './selectors-1a3c1725.js';
|
|
5
5
|
import mapJson from 'jsonpath-mapper';
|
|
6
6
|
import { to } from 'await-to-js';
|
|
7
|
-
import
|
|
7
|
+
import { L as LOGIN_COOKIE, R as REFRESH_TOKEN_COOKIE } from './CookieConstants-3d3b6531.js';
|
|
8
8
|
|
|
9
9
|
const findContentTypeMapping = (ContentTypeMappings, contentTypeId) => ContentTypeMappings.find(ct => ct.contentTypeID === contentTypeId);
|
|
10
10
|
|
|
@@ -52,9 +52,15 @@ const getManagementApiClient = async ({
|
|
|
52
52
|
}
|
|
53
53
|
};
|
|
54
54
|
}
|
|
55
|
-
|
|
55
|
+
let {
|
|
56
56
|
Client
|
|
57
57
|
} = await import('contensis-management-api');
|
|
58
|
+
if (typeof window === 'undefined') {
|
|
59
|
+
const {
|
|
60
|
+
UniversalClient
|
|
61
|
+
} = await import('contensis-management-api');
|
|
62
|
+
Client = UniversalClient;
|
|
63
|
+
}
|
|
58
64
|
const client = Client.create({
|
|
59
65
|
...config,
|
|
60
66
|
projectId,
|
|
@@ -68,32 +74,6 @@ const getManagementApiClient = async ({
|
|
|
68
74
|
return client;
|
|
69
75
|
};
|
|
70
76
|
|
|
71
|
-
const COOKIE_VALID_DAYS = 1; // 0 = Session cookie
|
|
72
|
-
|
|
73
|
-
// Override the default js-cookie conversion / encoding
|
|
74
|
-
// methods so the written values work with Contensis sites
|
|
75
|
-
const Cookies = JSCookie.withConverter({
|
|
76
|
-
read: value => decodeURIComponent(value),
|
|
77
|
-
write: value => encodeURIComponent(value)
|
|
78
|
-
});
|
|
79
|
-
class CookieHelper {
|
|
80
|
-
static GetCookie(name) {
|
|
81
|
-
const cookie = Cookies.get(name);
|
|
82
|
-
if (typeof cookie === 'undefined') {
|
|
83
|
-
return null;
|
|
84
|
-
}
|
|
85
|
-
return cookie;
|
|
86
|
-
}
|
|
87
|
-
static SetCookie(name, value, maxAgeDays = COOKIE_VALID_DAYS) {
|
|
88
|
-
if (maxAgeDays === 0) Cookies.set(name, value);else Cookies.set(name, value, {
|
|
89
|
-
expires: maxAgeDays
|
|
90
|
-
});
|
|
91
|
-
}
|
|
92
|
-
static DeleteCookie(name) {
|
|
93
|
-
Cookies.remove(name);
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
|
|
97
77
|
const context$1 = typeof window != 'undefined' ? window : global;
|
|
98
78
|
const requireOidc = process.env.NODE_ENV === 'development' ? WSFED_LOGIN === 'true' /* global WSFED_LOGIN */ : context$1.WSFED_LOGIN === 'true';
|
|
99
79
|
const servers = SERVERS; /* global SERVERS */
|
|
@@ -121,30 +101,32 @@ const createUserManager = async config => {
|
|
|
121
101
|
};
|
|
122
102
|
|
|
123
103
|
/* eslint-disable require-atomic-updates */
|
|
124
|
-
const LOGIN_COOKIE = 'ContensisCMSUserName';
|
|
125
|
-
const REFRESH_TOKEN_COOKIE = 'RefreshToken';
|
|
126
104
|
const context = typeof window != 'undefined' ? window : global;
|
|
127
105
|
class LoginHelper {
|
|
128
|
-
|
|
106
|
+
constructor(cookies) {
|
|
107
|
+
this.cookies = void 0;
|
|
108
|
+
this.cookies = cookies;
|
|
109
|
+
}
|
|
110
|
+
SetLoginCookies({
|
|
129
111
|
contensisClassicToken,
|
|
130
112
|
refreshToken
|
|
131
113
|
}) {
|
|
132
114
|
console.info('SetLoginCookies:', LOGIN_COOKIE, contensisClassicToken, REFRESH_TOKEN_COOKIE, refreshToken);
|
|
133
|
-
if (contensisClassicToken)
|
|
134
|
-
if (refreshToken)
|
|
115
|
+
if (contensisClassicToken) this.cookies.SetCookie(LOGIN_COOKIE, contensisClassicToken);
|
|
116
|
+
if (refreshToken) this.cookies.SetCookie(REFRESH_TOKEN_COOKIE, refreshToken);
|
|
135
117
|
}
|
|
136
|
-
|
|
118
|
+
GetCachedCredentials() {
|
|
137
119
|
return {
|
|
138
120
|
bearerToken: null,
|
|
139
121
|
bearerTokenExpiryDate: null,
|
|
140
|
-
refreshToken:
|
|
122
|
+
refreshToken: this.cookies.GetCookie(REFRESH_TOKEN_COOKIE),
|
|
141
123
|
refreshTokenExpiryDate: null,
|
|
142
|
-
contensisClassicToken:
|
|
124
|
+
contensisClassicToken: this.cookies.GetCookie(LOGIN_COOKIE)
|
|
143
125
|
};
|
|
144
126
|
}
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
127
|
+
ClearCachedCredentials() {
|
|
128
|
+
this.cookies.DeleteCookie(LOGIN_COOKIE);
|
|
129
|
+
this.cookies.DeleteCookie(REFRESH_TOKEN_COOKIE);
|
|
148
130
|
if (LoginHelper.WSFED_LOGIN && typeof window !== 'undefined') {
|
|
149
131
|
// remove any oidc keys left over in localStorage
|
|
150
132
|
const {
|
|
@@ -158,7 +140,7 @@ class LoginHelper {
|
|
|
158
140
|
keys.forEach(key => localStorage.removeItem(key));
|
|
159
141
|
}
|
|
160
142
|
}
|
|
161
|
-
|
|
143
|
+
async LoginUser({
|
|
162
144
|
username,
|
|
163
145
|
password,
|
|
164
146
|
clientCredentials
|
|
@@ -191,14 +173,14 @@ class LoginHelper {
|
|
|
191
173
|
isAuthenticationError: loginError.name.includes('ContensisAuthenticationError'),
|
|
192
174
|
isError: true
|
|
193
175
|
};
|
|
194
|
-
|
|
176
|
+
this.ClearCachedCredentials();
|
|
195
177
|
}
|
|
196
178
|
|
|
197
179
|
// Got a token using username and password
|
|
198
180
|
if (clientBearerToken) {
|
|
199
181
|
// Set credentials so we can continue to GetUserDetails
|
|
200
182
|
credentials = mapClientCredentials(transientClient);
|
|
201
|
-
|
|
183
|
+
this.SetLoginCookies(credentials);
|
|
202
184
|
authenticationState = {
|
|
203
185
|
clientCredentials: credentials,
|
|
204
186
|
isAuthenticated: true,
|
|
@@ -222,11 +204,11 @@ class LoginHelper {
|
|
|
222
204
|
isAuthenticationError: false,
|
|
223
205
|
isError: true
|
|
224
206
|
};
|
|
225
|
-
|
|
207
|
+
this.ClearCachedCredentials();
|
|
226
208
|
} else {
|
|
227
209
|
// Ensure we get latest refreshToken and contensisClassicToken from the latest client
|
|
228
210
|
const latestCredentials = mapClientCredentials(client);
|
|
229
|
-
|
|
211
|
+
this.SetLoginCookies(latestCredentials);
|
|
230
212
|
user = userDetails;
|
|
231
213
|
authenticationState = {
|
|
232
214
|
clientCredentials: latestCredentials,
|
|
@@ -241,8 +223,8 @@ class LoginHelper {
|
|
|
241
223
|
user
|
|
242
224
|
};
|
|
243
225
|
}
|
|
244
|
-
|
|
245
|
-
|
|
226
|
+
LogoutUser(redirectPath) {
|
|
227
|
+
this.ClearCachedCredentials();
|
|
246
228
|
if (LoginHelper.WSFED_LOGIN) {
|
|
247
229
|
LoginHelper.WsFedLogout(redirectPath);
|
|
248
230
|
} else {
|
|
@@ -264,6 +246,7 @@ class LoginHelper {
|
|
|
264
246
|
}
|
|
265
247
|
}
|
|
266
248
|
static async ClientRedirectToSignInPage(redirectPath) {
|
|
249
|
+
if (typeof location === 'undefined') return;
|
|
267
250
|
if (LoginHelper.WSFED_LOGIN) {
|
|
268
251
|
await LoginHelper.WsFedLogout();
|
|
269
252
|
await LoginHelper.WsFedLogin();
|
|
@@ -335,6 +318,7 @@ class LoginHelper {
|
|
|
335
318
|
ApplicationData = []
|
|
336
319
|
} = body;
|
|
337
320
|
if (LogonResult !== 0) {
|
|
321
|
+
console.info(`Security token is invalid - LogonResult: ${LogonResult}`);
|
|
338
322
|
return [{
|
|
339
323
|
message: 'Security token is invalid',
|
|
340
324
|
data: ApplicationData
|
|
@@ -377,6 +361,7 @@ LoginHelper.CMS_URL = SERVERS.cms /* global SERVERS */;
|
|
|
377
361
|
LoginHelper.WSFED_LOGIN = process.env.NODE_ENV === 'development' ? WSFED_LOGIN === 'true' /* global WSFED_LOGIN */ : context.WSFED_LOGIN === 'true';
|
|
378
362
|
LoginHelper.LOGIN_ROUTE = '/account/login';
|
|
379
363
|
LoginHelper.ACCESS_DENIED_ROUTE = '/account/access-denied';
|
|
364
|
+
LoginHelper.withCookies = cookieHelper => new LoginHelper(cookieHelper);
|
|
380
365
|
LoginHelper.GetUserDetails = async client => {
|
|
381
366
|
let userError,
|
|
382
367
|
groupsError,
|
|
@@ -406,7 +391,9 @@ const loginSagas = [takeEvery(LOGIN_USER, loginUserSaga), takeEvery(LOGOUT_USER,
|
|
|
406
391
|
function* handleRequiresLoginSaga(action) {
|
|
407
392
|
var _entry$sys;
|
|
408
393
|
const {
|
|
394
|
+
cookies,
|
|
409
395
|
entry,
|
|
396
|
+
path,
|
|
410
397
|
requireLogin,
|
|
411
398
|
routes: {
|
|
412
399
|
ContentTypeMappings
|
|
@@ -435,14 +422,18 @@ function* handleRequiresLoginSaga(action) {
|
|
|
435
422
|
// If cookies or securityToken are found on any route change
|
|
436
423
|
// always validate and login the user
|
|
437
424
|
if (routeRequiresLogin) {
|
|
425
|
+
console.info(`Route requires login: ${path}`);
|
|
438
426
|
// If routeRequiresLogin do a blocking call that returns userLoggedIn
|
|
439
427
|
userLoggedIn = yield call(validateUserSaga, {
|
|
428
|
+
cookies,
|
|
440
429
|
securityToken
|
|
441
430
|
});
|
|
431
|
+
console.info(`User logged in: ${userLoggedIn}`);
|
|
442
432
|
}
|
|
443
433
|
// otherwise do a non blocking put to handle validation in the background
|
|
444
434
|
else yield put({
|
|
445
435
|
type: VALIDATE_USER,
|
|
436
|
+
cookies,
|
|
446
437
|
securityToken
|
|
447
438
|
});
|
|
448
439
|
}
|
|
@@ -457,13 +448,16 @@ function* handleRequiresLoginSaga(action) {
|
|
|
457
448
|
if (!groupMatch) LoginHelper.ClientRedirectToAccessDeniedPage(action.location.pathname);
|
|
458
449
|
}
|
|
459
450
|
}
|
|
451
|
+
return userLoggedIn;
|
|
460
452
|
}
|
|
461
453
|
function* validateUserSaga({
|
|
454
|
+
cookies,
|
|
462
455
|
securityToken
|
|
463
456
|
}) {
|
|
457
|
+
const login = LoginHelper.withCookies(cookies);
|
|
464
458
|
// Check for refreshToken in cookies
|
|
465
|
-
let clientCredentials =
|
|
466
|
-
if (securityToken || clientCredentials.refreshToken) {
|
|
459
|
+
let clientCredentials = login.GetCachedCredentials();
|
|
460
|
+
if (securityToken || clientCredentials.securityToken || clientCredentials.refreshToken) {
|
|
467
461
|
// We only attempt to validate the user if one of the stored
|
|
468
462
|
// tokens are found, in this case we set loading state manually
|
|
469
463
|
// so we don't need to set and unset loading if there are no stored
|
|
@@ -475,26 +469,36 @@ function* validateUserSaga({
|
|
|
475
469
|
});
|
|
476
470
|
// If we have just a security token we will call a CMS endpoint
|
|
477
471
|
// and provide us with a RefreshToken cookie we can use during login
|
|
478
|
-
|
|
479
|
-
|
|
480
|
-
|
|
481
|
-
|
|
482
|
-
|
|
483
|
-
|
|
484
|
-
|
|
485
|
-
|
|
472
|
+
if (securityToken || clientCredentials.securityToken && !clientCredentials.refreshToken) {
|
|
473
|
+
const [error, refreshToken] = yield LoginHelper.GetCredentialsForSecurityToken(securityToken || clientCredentials.securityToken);
|
|
474
|
+
if (refreshToken) {
|
|
475
|
+
// Set cookies and reload values
|
|
476
|
+
login.SetLoginCookies({
|
|
477
|
+
contensisClassicToken: securityToken,
|
|
478
|
+
refreshToken
|
|
479
|
+
});
|
|
480
|
+
clientCredentials = login.GetCachedCredentials();
|
|
481
|
+
}
|
|
482
|
+
if (error) {
|
|
483
|
+
login.ClearCachedCredentials();
|
|
484
|
+
yield put({
|
|
485
|
+
type: SET_AUTHENTICATION_STATE,
|
|
486
|
+
authenticationState: {
|
|
487
|
+
isError: true,
|
|
488
|
+
errorMessage: (error === null || error === void 0 ? void 0 : error.message) || error && 'toString' in error && error.toString()
|
|
489
|
+
}
|
|
490
|
+
});
|
|
491
|
+
}
|
|
486
492
|
}
|
|
487
493
|
|
|
488
494
|
// Log the user in if a refreshToken is found
|
|
489
|
-
if (clientCredentials.refreshToken)
|
|
490
|
-
clientCredentials
|
|
491
|
-
|
|
492
|
-
|
|
493
|
-
|
|
494
|
-
|
|
495
|
-
|
|
496
|
-
}
|
|
497
|
-
});
|
|
495
|
+
if (clientCredentials.refreshToken) {
|
|
496
|
+
console.info(`Login user with refreshToken ${clientCredentials.refreshToken}`);
|
|
497
|
+
yield call(loginUserSaga, {
|
|
498
|
+
clientCredentials,
|
|
499
|
+
cookies: login.cookies
|
|
500
|
+
});
|
|
501
|
+
}
|
|
498
502
|
}
|
|
499
503
|
|
|
500
504
|
// Tell any callers have we successfully logged in?
|
|
@@ -504,8 +508,10 @@ function* loginUserSaga(action = {}) {
|
|
|
504
508
|
const {
|
|
505
509
|
username,
|
|
506
510
|
password,
|
|
507
|
-
clientCredentials
|
|
511
|
+
clientCredentials,
|
|
512
|
+
cookies
|
|
508
513
|
} = action;
|
|
514
|
+
const login = LoginHelper.withCookies(cookies);
|
|
509
515
|
|
|
510
516
|
// If a WSFED_LOGIN site has dispatched the loginUser action
|
|
511
517
|
// just redirect them to the Identity Provider sign in
|
|
@@ -513,7 +519,7 @@ function* loginUserSaga(action = {}) {
|
|
|
513
519
|
const {
|
|
514
520
|
authenticationState,
|
|
515
521
|
user
|
|
516
|
-
} = yield
|
|
522
|
+
} = yield login.LoginUser({
|
|
517
523
|
username,
|
|
518
524
|
password,
|
|
519
525
|
clientCredentials
|
|
@@ -549,13 +555,14 @@ function* redirectAfterSuccessfulLoginSaga() {
|
|
|
549
555
|
}
|
|
550
556
|
}
|
|
551
557
|
function* logoutUserSaga({
|
|
552
|
-
redirectPath
|
|
558
|
+
redirectPath,
|
|
559
|
+
cookies
|
|
553
560
|
}) {
|
|
554
561
|
yield put({
|
|
555
562
|
type: SET_AUTHENTICATION_STATE,
|
|
556
563
|
user: null
|
|
557
564
|
});
|
|
558
|
-
yield LoginHelper.LogoutUser(redirectPath);
|
|
565
|
+
yield LoginHelper.withCookies(cookies).LogoutUser(redirectPath);
|
|
559
566
|
}
|
|
560
567
|
function* refreshSecurityToken() {
|
|
561
568
|
const clientCredentials = yield select(selectClientCredentials, 'js');
|
|
@@ -572,4 +579,4 @@ function* refreshSecurityToken() {
|
|
|
572
579
|
}
|
|
573
580
|
|
|
574
581
|
export { LoginHelper as L, findContentTypeMapping as f, getManagementApiClient as g, handleRequiresLoginSaga as h, loginSagas as l, refreshSecurityToken as r };
|
|
575
|
-
//# sourceMappingURL=login-
|
|
582
|
+
//# sourceMappingURL=login-950e0b92.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"login-950e0b92.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"],"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 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 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"],"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","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","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"],"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-6cc0418c.js';
|
|
2
|
+
export { r as store } from './version-6cc0418c.js';
|
|
3
|
+
import { E as routing$1, D as action, F as routing$2, G as routing$3 } from './selectors-1a3c1725.js';
|
|
4
|
+
export { D as action, g as getIn, H as getJS } from './selectors-1a3c1725.js';
|
|
5
|
+
import { v as version$2, n as navigation$3 } from './version-ec722079.js';
|
|
6
|
+
export { c as convertSagaArray, b as injectReducer, i as injectRedux, d as injectSaga, u as useInjectRedux } from './version-ec722079.js';
|
|
7
7
|
import 'redux';
|
|
8
8
|
import 'redux-thunk';
|
|
9
9
|
import 'redux-saga';
|
package/esm/routing.js
CHANGED
|
@@ -1,12 +1,14 @@
|
|
|
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-1a3c1725.js';
|
|
2
|
+
export { R as RouteLoader } from './RouteLoader-d36840dd.js';
|
|
3
3
|
import 'jsonpath-mapper';
|
|
4
4
|
import 'query-string';
|
|
5
5
|
import 'react';
|
|
6
|
+
import 'react-cookie';
|
|
6
7
|
import 'react-redux';
|
|
7
8
|
import 'react-hot-loader';
|
|
8
9
|
import 'react-router-dom';
|
|
9
10
|
import 'react-router-config';
|
|
10
11
|
import 'reselect';
|
|
11
|
-
import './ToJs-
|
|
12
|
+
import './ToJs-e1af7030.js';
|
|
13
|
+
import './CookieHelper.class-4d6ee27b.js';
|
|
12
14
|
//# sourceMappingURL=routing.js.map
|
package/esm/routing.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"routing.js","sources":[],"sourcesContent":[],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"routing.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;"}
|
|
@@ -38,7 +38,6 @@ const SET_ANCESTORS = `${ROUTING_PREFIX}_SET_ANCESTORS`;
|
|
|
38
38
|
const SET_SIBLINGS = `${ROUTING_PREFIX}_SET_SIBLINGS`;
|
|
39
39
|
const SET_ENTRY_ID = `${ROUTING_PREFIX}_SET_ENTRY_ID`;
|
|
40
40
|
const SET_SURROGATE_KEYS = `${ROUTING_PREFIX}_SET_SURROGATE_KEYS`;
|
|
41
|
-
const SET_NAVIGATION_NOT_FOUND = `${ROUTING_PREFIX}_SET_NOT_FOUND`;
|
|
42
41
|
const SET_NAVIGATION_PATH = `${ROUTING_PREFIX}_SET_NAVIGATION_PATH`;
|
|
43
42
|
const SET_TARGET_PROJECT = `${ROUTING_PREFIX}_SET_TARGET_PROJECT`;
|
|
44
43
|
const SET_ROUTE = `${ROUTING_PREFIX}_SET_ROUTE`;
|
|
@@ -53,23 +52,20 @@ var routing$2 = /*#__PURE__*/Object.freeze({
|
|
|
53
52
|
SET_SIBLINGS: SET_SIBLINGS,
|
|
54
53
|
SET_ENTRY_ID: SET_ENTRY_ID,
|
|
55
54
|
SET_SURROGATE_KEYS: SET_SURROGATE_KEYS,
|
|
56
|
-
SET_NAVIGATION_NOT_FOUND: SET_NAVIGATION_NOT_FOUND,
|
|
57
55
|
SET_NAVIGATION_PATH: SET_NAVIGATION_PATH,
|
|
58
56
|
SET_TARGET_PROJECT: SET_TARGET_PROJECT,
|
|
59
57
|
SET_ROUTE: SET_ROUTE,
|
|
60
58
|
UPDATE_LOADING_STATE: UPDATE_LOADING_STATE
|
|
61
59
|
});
|
|
62
60
|
|
|
63
|
-
const
|
|
64
|
-
notFound
|
|
65
|
-
});
|
|
66
|
-
const setNavigationPath = (path, location, staticRoute, withEvents, statePath, routes) => action(SET_NAVIGATION_PATH, {
|
|
61
|
+
const setNavigationPath = (path, location, staticRoute, withEvents, statePath, routes, cookies) => action(SET_NAVIGATION_PATH, {
|
|
67
62
|
path,
|
|
68
63
|
location,
|
|
69
64
|
staticRoute,
|
|
70
65
|
withEvents,
|
|
71
66
|
statePath,
|
|
72
|
-
routes
|
|
67
|
+
routes,
|
|
68
|
+
cookies
|
|
73
69
|
});
|
|
74
70
|
const setCurrentProject = (project, allowedGroups, hostname) => action(SET_TARGET_PROJECT, {
|
|
75
71
|
project,
|
|
@@ -90,7 +86,6 @@ const setSurrogateKeys = (keys, url) => action(SET_SURROGATE_KEYS, {
|
|
|
90
86
|
|
|
91
87
|
var routing$1 = /*#__PURE__*/Object.freeze({
|
|
92
88
|
__proto__: null,
|
|
93
|
-
setNotFound: setNotFound,
|
|
94
89
|
setNavigationPath: setNavigationPath,
|
|
95
90
|
setCurrentProject: setCurrentProject,
|
|
96
91
|
setRoute: setRoute,
|
|
@@ -183,4 +178,4 @@ var routing = /*#__PURE__*/Object.freeze({
|
|
|
183
178
|
});
|
|
184
179
|
|
|
185
180
|
export { setSurrogateKeys as A, SET_TARGET_PROJECT as B, SET_SURROGATE_KEYS as C, action as D, routing$2 as E, routing$1 as F, routing as G, getJS as H, SET_NAVIGATION_PATH as S, UPDATE_LOADING_STATE as U, selectRouteEntry as a, selectCurrentProject as b, setCurrentProject as c, SET_ROUTE as d, selectCurrentNode as e, selectCurrentAncestors as f, getImmutableOrJS as g, selectCurrentSiblings as h, selectRouteEntryEntryId as i, selectRouteEntryLanguage as j, selectMappedEntry as k, SET_ENTRY as l, SET_ANCESTORS as m, SET_SIBLINGS as n, selectCurrentSearch as o, setRoute as p, queryParams as q, selectRouteEntryContentTypeId as r, selectSurrogateKeys as s, selectRouteIsError as t, selectIsNotFound as u, selectRouteLoading as v, selectCurrentPath as w, selectRouteStatusCode as x, selectRouteErrorMessage as y, setNavigationPath as z };
|
|
186
|
-
//# sourceMappingURL=selectors-
|
|
181
|
+
//# sourceMappingURL=selectors-1a3c1725.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"selectors-1a3c1725.js","sources":["../src/redux/util.ts","../src/routing/redux/types.ts","../src/routing/redux/actions.ts","../src/util/navigation.js","../src/routing/redux/selectors.ts"],"sourcesContent":["import { jpath } from '~/util/json-mapper';\n\nexport const action = (type: string, payload: any = {}) => ({\n type,\n ...payload,\n});\n\nexport const getJS = <S extends Record<string, unknown>, T extends keyof S>(\n state: S,\n stateKey: T\n) => {\n if (\n 'get' in state &&\n typeof state.get === 'function' &&\n 'toJS' in state &&\n typeof state.toJS === 'function'\n ) {\n return state.get(stateKey) as S[T];\n }\n return state[stateKey];\n};\n\nexport const getImmutableOrJS = <\n S extends Record<string, unknown>,\n T extends keyof S | any\n>(\n state: S,\n stateKey: T | T[],\n fallbackValue?: any,\n returnType: 'immutable' | 'js' = globalThis.STATE_TYPE\n) => {\n // Find a fromJS function from global that is dynamically loaded in createStore\n // or replace with a stub function for non-immutable gets\n const fromJS =\n returnType === 'immutable'\n ? globalThis.immutable?.fromJSOrdered || globalThis.immutable?.fromJS\n : v => v;\n\n if (\n state &&\n 'get' in state &&\n typeof state.get === 'function' &&\n 'getIn' in state &&\n typeof state.getIn === 'function' &&\n 'toJS' in state &&\n typeof state.toJS === 'function'\n ) {\n if (Array.isArray(stateKey))\n return fromJS(state.getIn(stateKey, fallbackValue));\n return fromJS(state.get(stateKey, fallbackValue)) as S[T | any];\n }\n\n if (Array.isArray(stateKey) && state && typeof state === 'object') {\n const result = jpath(stateKey.join('.'), state);\n if (typeof result === 'undefined') return fallbackValue;\n return result;\n }\n\n const result =\n state && typeof state === 'object' ? state[stateKey as string] : undefined;\n if (typeof result === 'undefined') return fallbackValue;\n return result;\n};\n","const ROUTING_PREFIX = '@ROUTING/';\nexport const GET_ENTRY = `${ROUTING_PREFIX}_GET_ENTRY`;\nexport const SET_ENTRY = `${ROUTING_PREFIX}_SET_ENTRY`;\nexport const SET_NODE = `${ROUTING_PREFIX}_SET_NODE`;\nexport const SET_ANCESTORS = `${ROUTING_PREFIX}_SET_ANCESTORS`;\nexport const SET_SIBLINGS = `${ROUTING_PREFIX}_SET_SIBLINGS`;\nexport const SET_ENTRY_ID = `${ROUTING_PREFIX}_SET_ENTRY_ID`;\nexport const SET_SURROGATE_KEYS = `${ROUTING_PREFIX}_SET_SURROGATE_KEYS`;\n\nexport const SET_NAVIGATION_PATH = `${ROUTING_PREFIX}_SET_NAVIGATION_PATH`;\n\nexport const SET_TARGET_PROJECT = `${ROUTING_PREFIX}_SET_TARGET_PROJECT`;\n\nexport const SET_ROUTE = `${ROUTING_PREFIX}_SET_ROUTE`;\n\nexport const UPDATE_LOADING_STATE = `${ROUTING_PREFIX}_UPDATE_LOADING_STATE`;\n","import { useLocation } from 'react-router-dom';\nimport { action } from '~/redux/util';\nimport {\n SET_ENTRY,\n SET_NAVIGATION_PATH,\n SET_TARGET_PROJECT,\n SET_ROUTE,\n SET_SURROGATE_KEYS,\n} from './types';\n\nimport { Entry } from 'contensis-delivery-api/lib/models';\nimport { MatchedRoute, RouteConfig } from 'react-router-config';\nimport { AppRoutes, WithEvents } from '../routes';\nimport { CookieHelper } from '~/user/util/CookieHelper.class';\n\nexport const setNavigationPath = (\n path: string,\n location: ReturnType<typeof useLocation>,\n staticRoute: MatchedRoute<any, RouteConfig> | undefined,\n withEvents: WithEvents,\n statePath: string,\n routes: AppRoutes,\n cookies: CookieHelper\n) =>\n action(SET_NAVIGATION_PATH, {\n path,\n location,\n staticRoute,\n withEvents,\n statePath,\n routes,\n cookies,\n });\n\nexport const setCurrentProject = (\n project: string,\n allowedGroups: any,\n hostname: string\n) => action(SET_TARGET_PROJECT, { project, allowedGroups, hostname });\n\nexport const setRoute = (path: string, state?: any) =>\n action(SET_ROUTE, { path, state });\n\nexport const setRouteEntry = (entry: Entry) => action(SET_ENTRY, { entry });\n\nexport const setSurrogateKeys = (keys: string, url: string) =>\n action(SET_SURROGATE_KEYS, { keys, url });\n","import queryString from 'query-string';\n\nexport function queryParams(search) {\n return queryString.parse(\n typeof window != 'undefined' ? window.location.search : search\n );\n}\nexport const routeParams = staticRoute =>\n staticRoute && staticRoute.match ? staticRoute.match.params : {};\n\nexport const buildUrl = (route, params) => {\n const qs = queryString.stringify(params);\n const path = qs ? `${route}?${qs}` : route;\n return path;\n};\n\nexport const clientHostname = () =>\n `${window.location.protocol}//${window.location.hostname}:${window.location.port}`;\n","import { Entry } from 'contensis-delivery-api/lib/models';\nimport { StateType } from '~/config';\nimport { AppState } from '~/redux/appstate';\nimport { getImmutableOrJS as getIn } from '~/redux/util';\nimport { queryParams } from '~/util/navigation';\n\nexport const selectRouteEntry = (state: AppState, returnType?: StateType) =>\n getIn(state, ['routing', 'entry'], {} as Entry, returnType);\n\nexport const selectMappedEntry = (state: AppState, returnType?: StateType) =>\n getIn(state, ['routing', 'mappedEntry'], null, returnType);\n\nexport const selectSurrogateKeys = (state: AppState) => {\n const keys = getIn(state, ['routing', 'surrogateKeys'], [], 'js');\n return keys.join(' ');\n};\nexport const selectCurrentHostname = (state: AppState) =>\n getIn(state, ['routing', 'currentHostname']);\n\nexport const selectCurrentTreeID = (state: AppState) =>\n getIn(state, ['routing', 'currentHostname']);\n\nexport const selectRouteEntryEntryId = (state: AppState) =>\n getIn(state, ['routing', 'entry', 'sys', 'id'], null);\n\nexport const selectRouteEntryContentTypeId = (state: AppState) => {\n const entry = selectRouteEntry(state);\n return getIn(entry, ['sys', 'contentTypeId'], null);\n};\n\nexport const selectRouteEntryLanguage = (state: AppState) => {\n const entry = selectRouteEntry(state);\n return getIn(entry, ['sys', 'language'], null);\n};\n\nexport const selectRouteEntrySlug = (state: AppState) => {\n const entry = selectRouteEntry(state);\n return getIn(entry, ['sys', 'slug'], null);\n};\n\nexport const selectRouteEntryID = (state: AppState) =>\n getIn(state, ['routing', 'entryID']);\n\nexport const selectCanonicalPath = (state: AppState) => {\n return getIn(state, ['routing', 'canonicalPath']);\n};\n\nexport const selectCurrentPath = (state: AppState) =>\n getIn(state, ['routing', 'currentPath']);\n\nexport const selectCurrentLocation = (state: AppState) =>\n getIn(state, ['routing', 'location']);\nexport const selectCurrentSearch = (state: AppState) =>\n getIn(state, ['routing', 'location', 'search']);\nexport const selectCurrentHash = (state: AppState) =>\n getIn(state, ['routing', 'location', 'hash']);\nexport const selectQueryStringAsObject = (state: AppState) =>\n queryParams(selectCurrentSearch(state));\nexport const selectCurrentProject = (state: AppState) =>\n getIn(state, ['routing', 'currentProject']);\nexport const selectIsNotFound = (state: AppState) =>\n getIn(state, ['routing', 'notFound']);\nexport const selectCurrentAncestors = (state: AppState) =>\n getIn(state, ['routing', 'currentNodeAncestors'], []);\nexport const selectCurrentSiblings = (state: AppState) =>\n getIn(state, ['routing', 'currentNodeSiblings'], []);\nexport const selectCurrentNode = (state: AppState, returnType?: StateType) =>\n getIn(state, ['routing', 'currentNode'], null, returnType);\nexport const selectCurrentChildren = state =>\n getIn(state, ['routing', 'currentNode', 'children'], []);\n\nexport const selectBreadcrumb = (state: AppState) => {\n return [...selectCurrentAncestors(state), selectCurrentNode(state)];\n};\nexport const selectRouteErrorMessage = (state: AppState) => {\n const error = getIn(state, ['routing', 'error']);\n return getIn(error, ['data', 'message'], getIn(error, 'statusText'));\n};\nexport const selectRouteIsError = (state: AppState) =>\n getIn(state, ['routing', 'isError']);\nexport const selectRouteLoading = (state: AppState) =>\n getIn(state, ['routing', 'isLoading']);\nexport const selectRouteStatusCode = (state: AppState) =>\n getIn(state, ['routing', 'statusCode']);\nexport const selectStaticRoute = (state: AppState) =>\n getIn(state, ['routing', 'staticRoute']);\n"],"names":["action","type","payload","getJS","state","stateKey","get","toJS","getImmutableOrJS","fallbackValue","returnType","globalThis","STATE_TYPE","_globalThis$immutable","_globalThis$immutable2","fromJS","immutable","fromJSOrdered","v","getIn","Array","isArray","result","jpath","join","undefined","ROUTING_PREFIX","GET_ENTRY","SET_ENTRY","SET_NODE","SET_ANCESTORS","SET_SIBLINGS","SET_ENTRY_ID","SET_SURROGATE_KEYS","SET_NAVIGATION_PATH","SET_TARGET_PROJECT","SET_ROUTE","UPDATE_LOADING_STATE","setNavigationPath","path","location","staticRoute","withEvents","statePath","routes","cookies","setCurrentProject","project","allowedGroups","hostname","setRoute","setRouteEntry","entry","setSurrogateKeys","keys","url","queryParams","search","queryString","parse","window","selectRouteEntry","selectMappedEntry","selectSurrogateKeys","selectCurrentHostname","selectCurrentTreeID","selectRouteEntryEntryId","selectRouteEntryContentTypeId","selectRouteEntryLanguage","selectRouteEntrySlug","selectRouteEntryID","selectCanonicalPath","selectCurrentPath","selectCurrentLocation","selectCurrentSearch","selectCurrentHash","selectQueryStringAsObject","selectCurrentProject","selectIsNotFound","selectCurrentAncestors","selectCurrentSiblings","selectCurrentNode","selectCurrentChildren","selectBreadcrumb","selectRouteErrorMessage","error","selectRouteIsError","selectRouteLoading","selectRouteStatusCode","selectStaticRoute"],"mappings":"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"}
|