@zengenti/contensis-react-base 3.0.2-beta.36 → 3.0.2-beta.38
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/README.md +2 -2
- package/cjs/{App-ce3f1692.js → App-acce1d3b.js} +9 -9
- package/cjs/{App-ce3f1692.js.map → App-acce1d3b.js.map} +1 -1
- package/cjs/{ContensisDeliveryApi-39a28d8f.js → ContensisDeliveryApi-17b54492.js} +3 -3
- package/cjs/{ContensisDeliveryApi-39a28d8f.js.map → ContensisDeliveryApi-17b54492.js.map} +1 -1
- package/cjs/{RouteLoader-b8dfecc7.js → RouteLoader-a49e4e93.js} +3 -3
- package/cjs/{RouteLoader-b8dfecc7.js.map → RouteLoader-a49e4e93.js.map} +1 -1
- package/cjs/{ToJs-4099e8f0.js → ToJs-43cedc5c.js} +2 -5
- package/cjs/ToJs-43cedc5c.js.map +1 -0
- package/cjs/client.js +9 -10
- package/cjs/client.js.map +1 -1
- package/cjs/contensis-react-base.js +22 -15
- package/cjs/contensis-react-base.js.map +1 -1
- package/cjs/{login-d9b2597e.js → login-8eed92af.js} +6 -209
- package/cjs/login-8eed92af.js.map +1 -0
- package/cjs/{reducers-84b5db70.js → reducers-9afb5f89.js} +3 -13
- package/cjs/reducers-9afb5f89.js.map +1 -0
- package/cjs/redux.js +4 -5
- package/cjs/redux.js.map +1 -1
- package/cjs/routing.js +3 -3
- package/cjs/{selectors-c7873cd7.js → selectors-fa836926.js} +2 -2
- package/cjs/selectors-fa836926.js.map +1 -0
- package/cjs/user.js +4 -10
- package/cjs/user.js.map +1 -1
- package/cjs/util.js +4 -5
- package/cjs/util.js.map +1 -1
- package/cjs/{version-cd1fb272.js → version-430b7606.js} +8 -23
- package/cjs/version-430b7606.js.map +1 -0
- package/cjs/{version-94f16410.js → version-82c8a71b.js} +3 -3
- package/cjs/{version-94f16410.js.map → version-82c8a71b.js.map} +1 -1
- package/esm/{App-77fd1bc4.js → App-10d03a42.js} +9 -9
- package/esm/{App-77fd1bc4.js.map → App-10d03a42.js.map} +1 -1
- package/esm/{ContensisDeliveryApi-79fea22b.js → ContensisDeliveryApi-0040d62d.js} +3 -3
- package/esm/{ContensisDeliveryApi-79fea22b.js.map → ContensisDeliveryApi-0040d62d.js.map} +1 -1
- package/esm/{RouteLoader-18ea9f04.js → RouteLoader-58774c81.js} +3 -3
- package/esm/{RouteLoader-18ea9f04.js.map → RouteLoader-58774c81.js.map} +1 -1
- package/esm/{ToJs-03fa077a.js → ToJs-b18ab86e.js} +3 -5
- package/esm/ToJs-b18ab86e.js.map +1 -0
- package/esm/client.js +10 -11
- package/esm/client.js.map +1 -1
- package/esm/contensis-react-base.js +23 -16
- package/esm/contensis-react-base.js.map +1 -1
- package/esm/{login-daaa5f35.js → login-e4b1447e.js} +6 -209
- package/esm/login-e4b1447e.js.map +1 -0
- package/esm/{reducers-74f651dd.js → reducers-3d5c37d1.js} +4 -13
- package/esm/reducers-3d5c37d1.js.map +1 -0
- package/esm/redux.js +7 -8
- package/esm/redux.js.map +1 -1
- package/esm/routing.js +3 -3
- package/esm/{selectors-ff21e98a.js → selectors-62746dce.js} +2 -2
- package/esm/selectors-62746dce.js.map +1 -0
- package/esm/user.js +6 -12
- package/esm/user.js.map +1 -1
- package/esm/util.js +4 -5
- package/esm/util.js.map +1 -1
- package/esm/{version-2721f36b.js → version-43590cb2.js} +3 -3
- package/esm/{version-2721f36b.js.map → version-43590cb2.js.map} +1 -1
- package/esm/{version-9fb5f2a3.js → version-5c0924cc.js} +9 -23
- package/esm/version-5c0924cc.js.map +1 -0
- package/models/redux/appstate.d.ts +0 -1
- package/models/user/hooks/useLogin.d.ts +0 -2
- package/models/user/redux/actions.d.ts +0 -1
- package/models/user/redux/reducers.d.ts +0 -1
- package/models/user/redux/sagas/login.d.ts +3 -1
- package/models/user/redux/selectors.d.ts +0 -1
- package/models/user/redux/types.d.ts +0 -1
- package/models/user/util/LoginHelper.class.d.ts +1 -34
- package/package.json +1 -1
- package/cjs/ToJs-4099e8f0.js.map +0 -1
- package/cjs/login-d9b2597e.js.map +0 -1
- package/cjs/reducers-84b5db70.js.map +0 -1
- package/cjs/selectors-c7873cd7.js.map +0 -1
- package/cjs/version-cd1fb272.js.map +0 -1
- package/esm/ToJs-03fa077a.js.map +0 -1
- package/esm/login-daaa5f35.js.map +0 -1
- package/esm/reducers-74f651dd.js.map +0 -1
- package/esm/selectors-ff21e98a.js.map +0 -1
- package/esm/version-9fb5f2a3.js.map +0 -1
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
3
|
var effects = require('@redux-saga/core/effects');
|
|
4
|
-
var reducers = require('./reducers-
|
|
5
|
-
var ToJs = require('./ToJs-
|
|
6
|
-
var selectors = require('./selectors-
|
|
4
|
+
var reducers = require('./reducers-9afb5f89.js');
|
|
5
|
+
var ToJs = require('./ToJs-43cedc5c.js');
|
|
6
|
+
var selectors = require('./selectors-fa836926.js');
|
|
7
7
|
var mapJson = require('jsonpath-mapper');
|
|
8
8
|
var awaitToJs = require('await-to-js');
|
|
9
9
|
var JSCookie = require('js-cookie');
|
|
@@ -150,8 +150,6 @@ const LOGIN_COOKIE = 'ContensisCMSUserName';
|
|
|
150
150
|
const REFRESH_TOKEN_COOKIE = 'RefreshToken';
|
|
151
151
|
const context = typeof window != 'undefined' ? window : global;
|
|
152
152
|
class LoginHelper {
|
|
153
|
-
/* global TWO_FACTOR_AUTH */
|
|
154
|
-
|
|
155
153
|
static SetLoginCookies({
|
|
156
154
|
contensisClassicToken,
|
|
157
155
|
refreshToken
|
|
@@ -185,141 +183,7 @@ class LoginHelper {
|
|
|
185
183
|
keys.forEach(key => localStorage.removeItem(key));
|
|
186
184
|
}
|
|
187
185
|
}
|
|
188
|
-
static async
|
|
189
|
-
username,
|
|
190
|
-
password,
|
|
191
|
-
clientCredentials,
|
|
192
|
-
userIn,
|
|
193
|
-
twoFaToken
|
|
194
|
-
}) {
|
|
195
|
-
let authenticationState = {
|
|
196
|
-
clientCredentials: null,
|
|
197
|
-
isAuthenticated: false,
|
|
198
|
-
isAuthenticationError: false,
|
|
199
|
-
isError: false
|
|
200
|
-
};
|
|
201
|
-
let transientClient;
|
|
202
|
-
let user = userIn;
|
|
203
|
-
let credentials = clientCredentials;
|
|
204
|
-
if (user && credentials && twoFaToken) {
|
|
205
|
-
const [authTokenError, authTokenResponse] = await LoginHelper.VerifyTwoFaAuthToken(user.username, twoFaToken);
|
|
206
|
-
if (authTokenResponse !== null && authTokenResponse !== void 0 && authTokenResponse.isTokenValid) {
|
|
207
|
-
LoginHelper.SetLoginCookies(clientCredentials);
|
|
208
|
-
authenticationState = {
|
|
209
|
-
requiresTwoFa: false,
|
|
210
|
-
clientCredentials: clientCredentials,
|
|
211
|
-
isAuthenticated: true,
|
|
212
|
-
isAuthenticationError: false,
|
|
213
|
-
isError: false
|
|
214
|
-
};
|
|
215
|
-
} else {
|
|
216
|
-
const errorMessage = authTokenError || (authTokenResponse === null || authTokenResponse === void 0 ? void 0 : authTokenResponse.error) || 'Unknown error';
|
|
217
|
-
authenticationState = {
|
|
218
|
-
requiresTwoFa: true,
|
|
219
|
-
clientCredentials: clientCredentials,
|
|
220
|
-
errorMessage,
|
|
221
|
-
isAuthenticated: false,
|
|
222
|
-
isAuthenticationError: false,
|
|
223
|
-
isError: true
|
|
224
|
-
};
|
|
225
|
-
LoginHelper.ClearCachedCredentials();
|
|
226
|
-
// eslint-disable-next-line no-console
|
|
227
|
-
console.log('Error verifying 2fa token: ', errorMessage);
|
|
228
|
-
}
|
|
229
|
-
} else if (username && password) {
|
|
230
|
-
// Get a management client with username and password
|
|
231
|
-
transientClient = await getManagementApiClient({
|
|
232
|
-
username,
|
|
233
|
-
password
|
|
234
|
-
});
|
|
235
|
-
|
|
236
|
-
// Ensure the client has requested a bearer token
|
|
237
|
-
const [loginError, clientBearerToken] = await awaitToJs.to(transientClient.ensureBearerToken());
|
|
238
|
-
|
|
239
|
-
// Problem getting token with username and password
|
|
240
|
-
if (loginError) {
|
|
241
|
-
authenticationState = {
|
|
242
|
-
clientCredentials: null,
|
|
243
|
-
errorMessage: loginError.message || null,
|
|
244
|
-
isAuthenticated: false,
|
|
245
|
-
isAuthenticationError: loginError.name.includes('ContensisAuthenticationError'),
|
|
246
|
-
isError: true
|
|
247
|
-
};
|
|
248
|
-
LoginHelper.ClearCachedCredentials();
|
|
249
|
-
}
|
|
250
|
-
|
|
251
|
-
// Got a token using username and password
|
|
252
|
-
if (clientBearerToken) {
|
|
253
|
-
// Next, we need to request the 2fa token
|
|
254
|
-
const [tokenError] = await LoginHelper.RequestTwoFaAuthToken(username);
|
|
255
|
-
if (tokenError) {
|
|
256
|
-
// eslint-disable-next-line no-console
|
|
257
|
-
console.log(`Error requesting two-factor auth token: ${tokenError}`);
|
|
258
|
-
authenticationState = {
|
|
259
|
-
clientCredentials: null,
|
|
260
|
-
errorMessage: tokenError || null,
|
|
261
|
-
isAuthenticated: false,
|
|
262
|
-
isAuthenticationError: false,
|
|
263
|
-
isError: true
|
|
264
|
-
};
|
|
265
|
-
LoginHelper.ClearCachedCredentials();
|
|
266
|
-
} else {
|
|
267
|
-
// If we have successfully generated a 2fa token, get the user details next
|
|
268
|
-
const [userDetailsError, userDetails] = await LoginHelper.GetUserDetails(transientClient);
|
|
269
|
-
if (userDetailsError) {
|
|
270
|
-
authenticationState = {
|
|
271
|
-
clientCredentials: null,
|
|
272
|
-
errorMessage: userDetailsError.message,
|
|
273
|
-
isAuthenticated: false,
|
|
274
|
-
isAuthenticationError: false,
|
|
275
|
-
isError: true
|
|
276
|
-
};
|
|
277
|
-
LoginHelper.ClearCachedCredentials();
|
|
278
|
-
} else {
|
|
279
|
-
user = userDetails;
|
|
280
|
-
const credentials = mapClientCredentials(transientClient);
|
|
281
|
-
authenticationState = {
|
|
282
|
-
requiresTwoFa: true,
|
|
283
|
-
clientCredentials: credentials,
|
|
284
|
-
errorMessage: null,
|
|
285
|
-
isAuthenticated: false,
|
|
286
|
-
isAuthenticationError: false,
|
|
287
|
-
isError: false
|
|
288
|
-
};
|
|
289
|
-
}
|
|
290
|
-
}
|
|
291
|
-
}
|
|
292
|
-
} else if (credentials) {
|
|
293
|
-
const client = transientClient || (await getManagementApiClient(credentials));
|
|
294
|
-
const [error, userDetails] = await LoginHelper.GetUserDetails(client);
|
|
295
|
-
if (error) {
|
|
296
|
-
authenticationState = {
|
|
297
|
-
clientCredentials: null,
|
|
298
|
-
errorMessage: error.message,
|
|
299
|
-
isAuthenticated: false,
|
|
300
|
-
isAuthenticationError: false,
|
|
301
|
-
isError: true
|
|
302
|
-
};
|
|
303
|
-
LoginHelper.ClearCachedCredentials();
|
|
304
|
-
} else {
|
|
305
|
-
// Ensure we get latest refreshToken and contensisClassicToken from the latest client
|
|
306
|
-
const latestCredentials = mapClientCredentials(client);
|
|
307
|
-
LoginHelper.SetLoginCookies(latestCredentials);
|
|
308
|
-
user = userDetails;
|
|
309
|
-
authenticationState = {
|
|
310
|
-
clientCredentials: latestCredentials,
|
|
311
|
-
isAuthenticated: true,
|
|
312
|
-
isAuthenticationError: false,
|
|
313
|
-
isError: false
|
|
314
|
-
};
|
|
315
|
-
}
|
|
316
|
-
}
|
|
317
|
-
return {
|
|
318
|
-
authenticationState,
|
|
319
|
-
user
|
|
320
|
-
};
|
|
321
|
-
}
|
|
322
|
-
static async LoginUserRegular({
|
|
186
|
+
static async LoginUser({
|
|
323
187
|
username,
|
|
324
188
|
password,
|
|
325
189
|
clientCredentials
|
|
@@ -402,25 +266,6 @@ class LoginHelper {
|
|
|
402
266
|
user
|
|
403
267
|
};
|
|
404
268
|
}
|
|
405
|
-
static async LoginUser({
|
|
406
|
-
username,
|
|
407
|
-
password,
|
|
408
|
-
clientCredentials,
|
|
409
|
-
userIn,
|
|
410
|
-
twoFaToken
|
|
411
|
-
}) {
|
|
412
|
-
return LoginHelper.IS_TWO_FA ? LoginHelper.LoginUserTwoFactorAuth({
|
|
413
|
-
username,
|
|
414
|
-
password,
|
|
415
|
-
clientCredentials,
|
|
416
|
-
userIn,
|
|
417
|
-
twoFaToken
|
|
418
|
-
}) : LoginHelper.LoginUserRegular({
|
|
419
|
-
username,
|
|
420
|
-
password,
|
|
421
|
-
clientCredentials
|
|
422
|
-
});
|
|
423
|
-
}
|
|
424
269
|
static LogoutUser(redirectPath) {
|
|
425
270
|
LoginHelper.ClearCachedCredentials();
|
|
426
271
|
if (LoginHelper.WSFED_LOGIN) {
|
|
@@ -557,34 +402,6 @@ LoginHelper.CMS_URL = SERVERS.cms /* global SERVERS */;
|
|
|
557
402
|
LoginHelper.WSFED_LOGIN = process.env.NODE_ENV === 'development' ? WSFED_LOGIN === 'true' /* global WSFED_LOGIN */ : context.WSFED_LOGIN === 'true';
|
|
558
403
|
LoginHelper.LOGIN_ROUTE = '/account/login';
|
|
559
404
|
LoginHelper.ACCESS_DENIED_ROUTE = '/account/access-denied';
|
|
560
|
-
LoginHelper.IS_TWO_FA = typeof TWO_FACTOR_AUTH === 'undefined' ? false : TWO_FACTOR_AUTH;
|
|
561
|
-
LoginHelper.RequestTwoFaAuthToken = async username => {
|
|
562
|
-
const [error, res] = await awaitToJs.to(fetch(`/account/token`, {
|
|
563
|
-
method: 'POST',
|
|
564
|
-
headers: {
|
|
565
|
-
Accept: 'application/json',
|
|
566
|
-
'Content-Type': 'application/json'
|
|
567
|
-
},
|
|
568
|
-
body: JSON.stringify({
|
|
569
|
-
username
|
|
570
|
-
})
|
|
571
|
-
}));
|
|
572
|
-
return [error, res];
|
|
573
|
-
};
|
|
574
|
-
LoginHelper.VerifyTwoFaAuthToken = async (username, token) => {
|
|
575
|
-
const [error, res] = await awaitToJs.to(fetch(`/account/token/verify`, {
|
|
576
|
-
method: 'POST',
|
|
577
|
-
headers: {
|
|
578
|
-
Accept: 'application/json',
|
|
579
|
-
'Content-Type': 'application/json'
|
|
580
|
-
},
|
|
581
|
-
body: JSON.stringify({
|
|
582
|
-
username,
|
|
583
|
-
token
|
|
584
|
-
})
|
|
585
|
-
}).then(res => res.json()));
|
|
586
|
-
return [error, res];
|
|
587
|
-
};
|
|
588
405
|
LoginHelper.GetUserDetails = async client => {
|
|
589
406
|
let userError,
|
|
590
407
|
groupsError,
|
|
@@ -610,7 +427,7 @@ LoginHelper.GetUserDetails = async client => {
|
|
|
610
427
|
return [userError, user];
|
|
611
428
|
};
|
|
612
429
|
|
|
613
|
-
const loginSagas = [effects.takeEvery(reducers.LOGIN_USER, loginUserSaga), effects.takeEvery(reducers.
|
|
430
|
+
const loginSagas = [effects.takeEvery(reducers.LOGIN_USER, loginUserSaga), effects.takeEvery(reducers.LOGOUT_USER, logoutUserSaga), effects.takeEvery(reducers.VALIDATE_USER, validateUserSaga), effects.takeEvery(reducers.SET_AUTHENTICATION_STATE, redirectAfterSuccessfulLoginSaga)];
|
|
614
431
|
function* handleRequiresLoginSaga(action) {
|
|
615
432
|
var _entry$sys;
|
|
616
433
|
const {
|
|
@@ -732,26 +549,6 @@ function* loginUserSaga(action = {}) {
|
|
|
732
549
|
user
|
|
733
550
|
});
|
|
734
551
|
}
|
|
735
|
-
function* verifyTwoFaTokenSaga(action = {}) {
|
|
736
|
-
const {
|
|
737
|
-
twoFaToken
|
|
738
|
-
} = action;
|
|
739
|
-
const userIn = yield effects.select(ToJs.selectUser);
|
|
740
|
-
const clientCredentials = yield effects.select(ToJs.selectClientCredentials);
|
|
741
|
-
const {
|
|
742
|
-
authenticationState,
|
|
743
|
-
user
|
|
744
|
-
} = yield LoginHelper.LoginUser({
|
|
745
|
-
clientCredentials,
|
|
746
|
-
userIn,
|
|
747
|
-
twoFaToken
|
|
748
|
-
});
|
|
749
|
-
yield effects.put({
|
|
750
|
-
type: reducers.SET_AUTHENTICATION_STATE,
|
|
751
|
-
authenticationState,
|
|
752
|
-
user
|
|
753
|
-
});
|
|
754
|
-
}
|
|
755
552
|
const removeHostnamePart = path => {
|
|
756
553
|
// eslint-disable-next-line no-console
|
|
757
554
|
console.log(path);
|
|
@@ -805,4 +602,4 @@ exports.getManagementApiClient = getManagementApiClient;
|
|
|
805
602
|
exports.handleRequiresLoginSaga = handleRequiresLoginSaga;
|
|
806
603
|
exports.loginSagas = loginSagas;
|
|
807
604
|
exports.refreshSecurityToken = refreshSecurityToken;
|
|
808
|
-
//# sourceMappingURL=login-
|
|
605
|
+
//# sourceMappingURL=login-8eed92af.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"login-8eed92af.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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"}
|
|
@@ -6,7 +6,6 @@ const ACTION_PREFIX = '@USER/';
|
|
|
6
6
|
const VALIDATE_USER = `${ACTION_PREFIX}VALIDATE_USER`;
|
|
7
7
|
const SET_AUTHENTICATION_STATE = `${ACTION_PREFIX}SET_AUTHENTICATION_STATE`;
|
|
8
8
|
const LOGIN_USER = `${ACTION_PREFIX}LOGIN_USER`;
|
|
9
|
-
const VERIFY_TWO_FA_TOKEN = `${ACTION_PREFIX}VERIFY_TWO_FA_TOKEN`;
|
|
10
9
|
const LOGIN_SUCCESSFUL = `${ACTION_PREFIX}LOGIN_SUCCESSFUL`;
|
|
11
10
|
const LOGIN_FAILED = `${ACTION_PREFIX}LOGIN_FAILED`;
|
|
12
11
|
const LOGOUT_USER = `${ACTION_PREFIX}LOGOUT_USER`;
|
|
@@ -31,7 +30,6 @@ var types = /*#__PURE__*/Object.freeze({
|
|
|
31
30
|
VALIDATE_USER: VALIDATE_USER,
|
|
32
31
|
SET_AUTHENTICATION_STATE: SET_AUTHENTICATION_STATE,
|
|
33
32
|
LOGIN_USER: LOGIN_USER,
|
|
34
|
-
VERIFY_TWO_FA_TOKEN: VERIFY_TWO_FA_TOKEN,
|
|
35
33
|
LOGIN_SUCCESSFUL: LOGIN_SUCCESSFUL,
|
|
36
34
|
LOGIN_FAILED: LOGIN_FAILED,
|
|
37
35
|
LOGOUT_USER: LOGOUT_USER,
|
|
@@ -53,7 +51,6 @@ var types = /*#__PURE__*/Object.freeze({
|
|
|
53
51
|
});
|
|
54
52
|
|
|
55
53
|
const defaultAuthenticationState = {
|
|
56
|
-
requiresTwoFa: false,
|
|
57
54
|
clientCredentials: null,
|
|
58
55
|
errorMessage: null,
|
|
59
56
|
isAuthenticated: false,
|
|
@@ -103,7 +100,6 @@ var UserReducer = immer.produce((state, action) => {
|
|
|
103
100
|
}
|
|
104
101
|
const {
|
|
105
102
|
authenticationState: {
|
|
106
|
-
requiresTwoFa = false,
|
|
107
103
|
clientCredentials = null,
|
|
108
104
|
errorMessage = null,
|
|
109
105
|
isAuthenticated,
|
|
@@ -113,19 +109,14 @@ var UserReducer = immer.produce((state, action) => {
|
|
|
113
109
|
},
|
|
114
110
|
user
|
|
115
111
|
} = action;
|
|
116
|
-
|
|
117
|
-
// userObj is so we aren't trying to modify user prop directly, as it can be immutable
|
|
118
|
-
const userObj = {};
|
|
119
112
|
if (user) {
|
|
120
|
-
|
|
121
|
-
|
|
113
|
+
user.name = `${user.firstName}${user.lastName ? ` ${user.lastName}` : ''}` || null;
|
|
114
|
+
user.isZengentiStaff = user.email.includes('@zengenti.com');
|
|
122
115
|
}
|
|
123
116
|
state = {
|
|
124
117
|
...initialUserState,
|
|
125
118
|
...(user || state),
|
|
126
|
-
...userObj,
|
|
127
119
|
authenticationState: {
|
|
128
|
-
requiresTwoFa,
|
|
129
120
|
clientCredentials,
|
|
130
121
|
errorMessage,
|
|
131
122
|
isAuthenticated: isAuthenticated || ((_state = state) === null || _state === void 0 ? void 0 : (_state$authentication = _state.authenticationState) === null || _state$authentication === void 0 ? void 0 : _state$authentication.isAuthenticated),
|
|
@@ -240,7 +231,6 @@ exports.RESET_USER_PASSWORD_SUCCESS = RESET_USER_PASSWORD_SUCCESS;
|
|
|
240
231
|
exports.SET_AUTHENTICATION_STATE = SET_AUTHENTICATION_STATE;
|
|
241
232
|
exports.UserReducer = UserReducer;
|
|
242
233
|
exports.VALIDATE_USER = VALIDATE_USER;
|
|
243
|
-
exports.VERIFY_TWO_FA_TOKEN = VERIFY_TWO_FA_TOKEN;
|
|
244
234
|
exports.initialUserState = initialUserState;
|
|
245
235
|
exports.types = types;
|
|
246
|
-
//# sourceMappingURL=reducers-
|
|
236
|
+
//# sourceMappingURL=reducers-9afb5f89.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reducers-9afb5f89.js","sources":["../src/user/redux/types.js","../src/user/redux/reducers.ts"],"sourcesContent":["const ACTION_PREFIX = '@USER/';\nexport const VALIDATE_USER = `${ACTION_PREFIX}VALIDATE_USER`;\nexport const SET_AUTHENTICATION_STATE = `${ACTION_PREFIX}SET_AUTHENTICATION_STATE`;\nexport const LOGIN_USER = `${ACTION_PREFIX}LOGIN_USER`;\nexport const LOGIN_SUCCESSFUL = `${ACTION_PREFIX}LOGIN_SUCCESSFUL`;\nexport const LOGIN_FAILED = `${ACTION_PREFIX}LOGIN_FAILED`;\nexport const LOGOUT_USER = `${ACTION_PREFIX}LOGOUT_USER`;\nexport const REGISTER_USER = `${ACTION_PREFIX}REGISTER_USER`;\nexport const REGISTER_USER_SUCCESS = `${ACTION_PREFIX}REGISTER_USER_SUCCESS`;\nexport const REGISTER_USER_FAILED = `${ACTION_PREFIX}REGISTER_USER_FAILED`;\n\nexport const REQUEST_USER_PASSWORD_RESET = `${ACTION_PREFIX}REQUEST_USER_PASSWORD_RESET`;\nexport const RESET_USER_PASSWORD = `${ACTION_PREFIX}RESET_USER_PASSWORD`;\nexport const REQUEST_USER_PASSWORD_RESET_SENDING = `${ACTION_PREFIX}REQUEST_USER_PASSWORD_RESET_SENDING`;\nexport const REQUEST_USER_PASSWORD_RESET_SUCCESS = `${ACTION_PREFIX}REQUEST_USER_PASSWORD_RESET_SUCCESS`;\nexport const REQUEST_USER_PASSWORD_RESET_ERROR = `${ACTION_PREFIX}REQUEST_USER_PASSWORD_RESET_ERROR`;\nexport const RESET_USER_PASSWORD_SENDING = `${ACTION_PREFIX}RESET_USER_PASSWORD_SENDING`;\nexport const RESET_USER_PASSWORD_SUCCESS = `${ACTION_PREFIX}RESET_USER_PASSWORD_SUCCESS`;\nexport const RESET_USER_PASSWORD_ERROR = `${ACTION_PREFIX}RESET_USER_PASSWORD_ERROR`;\n\nexport const CHANGE_USER_PASSWORD = `${ACTION_PREFIX}CHANGE_USER_PASSWORD`;\nexport const CHANGE_USER_PASSWORD_SENDING = `${ACTION_PREFIX}CHANGE_USER_PASSWORD_SENDING`;\nexport const CHANGE_USER_PASSWORD_SUCCESS = `${ACTION_PREFIX}CHANGE_USER_PASSWORD_SUCCESS`;\nexport const CHANGE_USER_PASSWORD_ERROR = `${ACTION_PREFIX}CHANGE_USER_PASSWORD_ERROR`;\n","import { Draft, produce } from 'immer';\nimport { AppState } from '~/redux/appstate';\nimport {\n REGISTER_USER,\n REGISTER_USER_FAILED,\n REGISTER_USER_SUCCESS,\n SET_AUTHENTICATION_STATE,\n LOGIN_USER,\n LOGOUT_USER,\n REQUEST_USER_PASSWORD_RESET_SENDING,\n REQUEST_USER_PASSWORD_RESET_SUCCESS,\n REQUEST_USER_PASSWORD_RESET_ERROR,\n RESET_USER_PASSWORD_SENDING,\n RESET_USER_PASSWORD_SUCCESS,\n RESET_USER_PASSWORD_ERROR,\n CHANGE_USER_PASSWORD_SENDING,\n CHANGE_USER_PASSWORD_SUCCESS,\n CHANGE_USER_PASSWORD_ERROR,\n} from './types';\n\nconst defaultAuthenticationState = {\n clientCredentials: null,\n errorMessage: null,\n isAuthenticated: false,\n isAuthenticationError: false,\n isError: false,\n isLoading: false,\n};\n\nconst defaultPasswordResetRequestValues = {\n isSending: false,\n sent: false,\n error: null,\n};\n\nconst defaultResetPasswordValues = {\n isSending: false,\n sent: false,\n error: null,\n};\n\nconst defaultChangePasswordValues = {\n isSending: false,\n sent: false,\n error: null,\n};\n\nconst defaultRegistrationValues = {\n isLoading: false,\n success: false,\n error: null,\n};\n\nexport const initialUserState = {\n authenticationState: defaultAuthenticationState,\n passwordResetRequest: defaultPasswordResetRequestValues,\n resetPassword: defaultResetPasswordValues,\n changePassword: defaultChangePasswordValues,\n groups: [],\n};\n\nexport default produce((state: Draft<AppState['user']>, action) => {\n switch (action.type) {\n case LOGOUT_USER: {\n return initialUserState;\n }\n case LOGIN_USER:\n case SET_AUTHENTICATION_STATE: {\n if (!action.authenticationState) {\n action.authenticationState = defaultAuthenticationState;\n }\n\n const {\n authenticationState: {\n clientCredentials = null,\n errorMessage = null,\n isAuthenticated,\n isAuthenticationError = false,\n isError = false,\n isLoading = action.type === LOGIN_USER,\n },\n user,\n } = action;\n\n if (user) {\n user.name =\n `${user.firstName}${user.lastName ? ` ${user.lastName}` : ''}` ||\n null;\n user.isZengentiStaff = user.email.includes('@zengenti.com');\n }\n\n state = {\n ...initialUserState,\n ...(user || state),\n authenticationState: {\n clientCredentials,\n errorMessage,\n isAuthenticated:\n isAuthenticated || state?.authenticationState?.isAuthenticated,\n isAuthenticationError,\n isError,\n isLoading,\n },\n };\n return state;\n }\n // REGISTER_USER is the trigger to set the user.registration initial state\n // and will set user.registration.isLoading to true\n // REGISTER_USER_FAILED will unset user.registration.isLoading and will set\n // the value in user.registration.error\n // REGISTER_USER_SUCCESS will unset user.registration.isLoading and will\n // set user.registration to the created user from the api response\n case REGISTER_USER:\n case REGISTER_USER_FAILED:\n case REGISTER_USER_SUCCESS: {\n const { error, user } = action;\n\n // Set registration object from the supplied action.user\n // so we can call these values back later\n state.registration = (user ||\n state.registration ||\n defaultRegistrationValues) as typeof defaultRegistrationValues;\n\n // Set registration flags so the UI can track the status\n state.registration.success = action.type === REGISTER_USER_SUCCESS;\n state.registration.error = error || false;\n state.registration.isLoading = action.type === REGISTER_USER;\n return;\n }\n case REQUEST_USER_PASSWORD_RESET_SENDING:\n if (state.passwordResetRequest) {\n state.passwordResetRequest = { ...defaultPasswordResetRequestValues };\n state.passwordResetRequest.isSending = true;\n }\n return;\n case REQUEST_USER_PASSWORD_RESET_SUCCESS:\n if (state.passwordResetRequest) {\n state.passwordResetRequest.isSending = false;\n state.passwordResetRequest.sent = true;\n }\n return;\n case REQUEST_USER_PASSWORD_RESET_ERROR:\n if (state.passwordResetRequest) {\n state.passwordResetRequest.isSending = false;\n state.passwordResetRequest.error = action.error;\n }\n return;\n case RESET_USER_PASSWORD_SENDING:\n if (state.resetPassword) {\n state.resetPassword.isSending = true;\n }\n return;\n case RESET_USER_PASSWORD_SUCCESS:\n if (state.resetPassword) {\n state.resetPassword.isSending = false;\n state.resetPassword.sent = true;\n }\n return;\n case RESET_USER_PASSWORD_ERROR:\n if (state.resetPassword) {\n state.resetPassword.isSending = false;\n state.resetPassword.error = action.error;\n }\n return;\n case CHANGE_USER_PASSWORD_SENDING:\n if (state.changePassword) {\n state.changePassword.isSending = true;\n }\n return;\n case CHANGE_USER_PASSWORD_SUCCESS:\n if (state.changePassword) {\n state.changePassword.isSending = false;\n state.changePassword.sent = true;\n }\n return;\n case CHANGE_USER_PASSWORD_ERROR:\n if (state.changePassword) {\n state.changePassword.isSending = false;\n state.changePassword.error = action.error;\n }\n return;\n default:\n return;\n }\n}, initialUserState);\n"],"names":["ACTION_PREFIX","VALIDATE_USER","SET_AUTHENTICATION_STATE","LOGIN_USER","LOGIN_SUCCESSFUL","LOGIN_FAILED","LOGOUT_USER","REGISTER_USER","REGISTER_USER_SUCCESS","REGISTER_USER_FAILED","REQUEST_USER_PASSWORD_RESET","RESET_USER_PASSWORD","REQUEST_USER_PASSWORD_RESET_SENDING","REQUEST_USER_PASSWORD_RESET_SUCCESS","REQUEST_USER_PASSWORD_RESET_ERROR","RESET_USER_PASSWORD_SENDING","RESET_USER_PASSWORD_SUCCESS","RESET_USER_PASSWORD_ERROR","CHANGE_USER_PASSWORD","CHANGE_USER_PASSWORD_SENDING","CHANGE_USER_PASSWORD_SUCCESS","CHANGE_USER_PASSWORD_ERROR","defaultAuthenticationState","clientCredentials","errorMessage","isAuthenticated","isAuthenticationError","isError","isLoading","defaultPasswordResetRequestValues","isSending","sent","error","defaultResetPasswordValues","defaultChangePasswordValues","defaultRegistrationValues","success","initialUserState","authenticationState","passwordResetRequest","resetPassword","changePassword","groups","produce","state","action","type","_state","_state$authentication","user","name","firstName","lastName","isZengentiStaff","email","includes","registration"],"mappings":"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"}
|
package/cjs/redux.js
CHANGED
|
@@ -2,16 +2,15 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
-
var version$1 = require('./version-
|
|
6
|
-
var selectors$1 = require('./selectors-
|
|
7
|
-
var version$2 = require('./version-
|
|
5
|
+
var version$1 = require('./version-430b7606.js');
|
|
6
|
+
var selectors$1 = require('./selectors-fa836926.js');
|
|
7
|
+
var version$2 = require('./version-82c8a71b.js');
|
|
8
8
|
require('redux');
|
|
9
9
|
require('redux-thunk');
|
|
10
10
|
require('redux-saga');
|
|
11
11
|
require('redux-injectors');
|
|
12
12
|
require('immer');
|
|
13
|
-
require('
|
|
14
|
-
require('./reducers-84b5db70.js');
|
|
13
|
+
require('./reducers-9afb5f89.js');
|
|
15
14
|
require('jsonpath-mapper');
|
|
16
15
|
require('query-string');
|
|
17
16
|
require('@redux-saga/core/effects');
|
package/cjs/redux.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"redux.js","sources":["../src/redux/types/index.js","../src/redux/actions/navigation.js","../src/redux/actions/index.js","../src/redux/selectors/index.js","../src/redux/index.ts"],"sourcesContent":["import * as navigation from './navigation';\nimport * as routing from '~/routing/redux/types';\nimport * as version from './version';\n\nexport default { navigation, routing, version };\n","import { action } from '../util';\n\nimport { GET_NODE_TREE } from '~/redux/types/navigation';\n\nexport const loadNavigationTree = () => action(GET_NODE_TREE);\n","import * as navigation from './navigation';\nimport * as routing from '~/routing/redux/actions';\nimport * as version from './version';\n\nexport default { navigation, routing, version };\n","import * as navigation from './navigation';\nimport * as routing from '~/routing/redux/selectors';\nimport * as version from './version';\n\nexport default { navigation, routing, version };\n","import types from './types';\nimport actions from './actions';\nimport selectors from './selectors';\n\nexport { action, getJS, getImmutableOrJS as getIn } from './util';\n\nexport { reduxStore as store } from './store/store';\n\nexport {\n convertSagaArray,\n injectRedux,\n injectReducer,\n injectSaga,\n useInjectRedux,\n} from './store/injectors';\n\n// Remap the objects so they are presented in \"feature\" hierarchy\n// e.g. { routing: { types, actions }, navigation: { types, actions } }\n// instead of { types: { routing, navigation }, actions: { routing, navigation } }\n\nexport const navigation = {\n types: types.navigation,\n actions: actions.navigation,\n selectors: selectors.navigation,\n};\nexport const routing = {\n types: types.routing,\n actions: actions.routing,\n selectors: selectors.routing,\n};\nexport const version = {\n types: types.version,\n actions: actions.version,\n selectors: selectors.version,\n};\n"],"names":["navigation","routing","version","loadNavigationTree","action","GET_NODE_TREE","types","actions","selectors"],"mappings":"
|
|
1
|
+
{"version":3,"file":"redux.js","sources":["../src/redux/types/index.js","../src/redux/actions/navigation.js","../src/redux/actions/index.js","../src/redux/selectors/index.js","../src/redux/index.ts"],"sourcesContent":["import * as navigation from './navigation';\nimport * as routing from '~/routing/redux/types';\nimport * as version from './version';\n\nexport default { navigation, routing, version };\n","import { action } from '../util';\n\nimport { GET_NODE_TREE } from '~/redux/types/navigation';\n\nexport const loadNavigationTree = () => action(GET_NODE_TREE);\n","import * as navigation from './navigation';\nimport * as routing from '~/routing/redux/actions';\nimport * as version from './version';\n\nexport default { navigation, routing, version };\n","import * as navigation from './navigation';\nimport * as routing from '~/routing/redux/selectors';\nimport * as version from './version';\n\nexport default { navigation, routing, version };\n","import types from './types';\nimport actions from './actions';\nimport selectors from './selectors';\n\nexport { action, getJS, getImmutableOrJS as getIn } from './util';\n\nexport { reduxStore as store } from './store/store';\n\nexport {\n convertSagaArray,\n injectRedux,\n injectReducer,\n injectSaga,\n useInjectRedux,\n} from './store/injectors';\n\n// Remap the objects so they are presented in \"feature\" hierarchy\n// e.g. { routing: { types, actions }, navigation: { types, actions } }\n// instead of { types: { routing, navigation }, actions: { routing, navigation } }\n\nexport const navigation = {\n types: types.navigation,\n actions: actions.navigation,\n selectors: selectors.navigation,\n};\nexport const routing = {\n types: types.routing,\n actions: actions.routing,\n selectors: selectors.routing,\n};\nexport const version = {\n types: types.version,\n actions: actions.version,\n selectors: selectors.version,\n};\n"],"names":["navigation","routing","version","loadNavigationTree","action","GET_NODE_TREE","types","actions","selectors"],"mappings":";;;;;;;;;;;;;;;;;AAIA,YAAe;cAAEA,oBAAU;WAAEC,mBAAO;AAAEC,WAAAA,iBAAAA;AAAQ,CAAC;;ACAxC,MAAMC,kBAAkB,GAAGA,MAAMC,kBAAM,CAACC,uBAAa,CAAC;;;;;;;ACA7D,cAAe;cAAEL,YAAU;WAAEC,qBAAO;AAAEC,WAAAA,iBAAAA;AAAQ,CAAC;;ACA/C,gBAAe;cAAEF,oBAAU;WAAEC,qBAAO;AAAEC,WAAAA,mBAAAA;AAAQ,CAAC;;ACY/C;AACA;AACA;;AAEO,MAAMF,UAAU,GAAG;EACxBM,KAAK,EAAEA,KAAK,CAACN,UAAU;EACvBO,OAAO,EAAEA,OAAO,CAACP,UAAU;EAC3BQ,SAAS,EAAEA,SAAS,CAACR,UAAAA;AACvB,EAAC;AACM,MAAMC,OAAO,GAAG;EACrBK,KAAK,EAAEA,KAAK,CAACL,OAAO;EACpBM,OAAO,EAAEA,OAAO,CAACN,OAAO;EACxBO,SAAS,EAAEA,SAAS,CAACP,OAAAA;AACvB,EAAC;AACM,MAAMC,OAAO,GAAG;EACrBI,KAAK,EAAEA,KAAK,CAACJ,OAAO;EACpBK,OAAO,EAAEA,OAAO,CAACL,OAAO;EACxBM,SAAS,EAAEA,SAAS,CAACN,OAAAA;AACvB;;;;;;;;;;;;;;;;;;"}
|
package/cjs/routing.js
CHANGED
|
@@ -2,8 +2,8 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
-
var selectors = require('./selectors-
|
|
6
|
-
var RouteLoader = require('./RouteLoader-
|
|
5
|
+
var selectors = require('./selectors-fa836926.js');
|
|
6
|
+
var RouteLoader = require('./RouteLoader-a49e4e93.js');
|
|
7
7
|
require('jsonpath-mapper');
|
|
8
8
|
require('query-string');
|
|
9
9
|
require('react');
|
|
@@ -12,7 +12,7 @@ require('react-hot-loader');
|
|
|
12
12
|
require('react-router-dom');
|
|
13
13
|
require('react-router-config');
|
|
14
14
|
require('reselect');
|
|
15
|
-
require('./ToJs-
|
|
15
|
+
require('./ToJs-43cedc5c.js');
|
|
16
16
|
|
|
17
17
|
|
|
18
18
|
|
|
@@ -112,7 +112,7 @@ const selectRouteEntry = (state, returnType) => getImmutableOrJS(state, ['routin
|
|
|
112
112
|
const selectMappedEntry = (state, returnType) => getImmutableOrJS(state, ['routing', 'mappedEntry'], null, returnType);
|
|
113
113
|
const selectSurrogateKeys = state => {
|
|
114
114
|
const keys = getImmutableOrJS(state, ['routing', 'surrogateKeys'], [], 'js');
|
|
115
|
-
return keys
|
|
115
|
+
return keys;
|
|
116
116
|
};
|
|
117
117
|
const selectCurrentHostname = state => getImmutableOrJS(state, ['routing', 'currentHostname']);
|
|
118
118
|
const selectCurrentTreeID = state => getImmutableOrJS(state, ['routing', 'currentHostname']);
|
|
@@ -225,4 +225,4 @@ exports.setCurrentProject = setCurrentProject;
|
|
|
225
225
|
exports.setNavigationPath = setNavigationPath;
|
|
226
226
|
exports.setRoute = setRoute;
|
|
227
227
|
exports.setSurrogateKeys = setSurrogateKeys;
|
|
228
|
-
//# sourceMappingURL=selectors-
|
|
228
|
+
//# sourceMappingURL=selectors-fa836926.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"selectors-fa836926.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_NOT_FOUND = `${ROUTING_PREFIX}_SET_NOT_FOUND`;\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 { action } from '~/redux/util';\nimport {\n SET_ENTRY,\n SET_NAVIGATION_NOT_FOUND,\n SET_NAVIGATION_PATH,\n SET_TARGET_PROJECT,\n SET_ROUTE,\n SET_SURROGATE_KEYS,\n} from './types';\n\nexport const setNotFound = notFound =>\n action(SET_NAVIGATION_NOT_FOUND, { notFound });\nexport const setNavigationPath = (\n path,\n location,\n staticRoute,\n withEvents,\n statePath,\n routes\n) =>\n action(SET_NAVIGATION_PATH, {\n path,\n location,\n staticRoute,\n withEvents,\n statePath,\n routes,\n });\nexport const setCurrentProject = (project, allowedGroups, hostname) =>\n action(SET_TARGET_PROJECT, { project, allowedGroups, hostname });\nexport const setRoute = (path, state) => action(SET_ROUTE, { path, state });\nexport const setRouteEntry = entry => action(SET_ENTRY, { entry });\nexport const setSurrogateKeys = (keys, url) =>\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;\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_NOT_FOUND","SET_NAVIGATION_PATH","SET_TARGET_PROJECT","SET_ROUTE","UPDATE_LOADING_STATE","setNotFound","notFound","setNavigationPath","path","location","staticRoute","withEvents","statePath","routes","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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"}
|
package/cjs/user.js
CHANGED
|
@@ -2,11 +2,11 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
-
var login = require('./login-
|
|
5
|
+
var login = require('./login-8eed92af.js');
|
|
6
6
|
var reactRedux = require('react-redux');
|
|
7
|
-
var selectors = require('./selectors-
|
|
8
|
-
var reducers = require('./reducers-
|
|
9
|
-
var ToJs = require('./ToJs-
|
|
7
|
+
var selectors = require('./selectors-fa836926.js');
|
|
8
|
+
var reducers = require('./reducers-9afb5f89.js');
|
|
9
|
+
var ToJs = require('./ToJs-43cedc5c.js');
|
|
10
10
|
require('@redux-saga/core/effects');
|
|
11
11
|
require('jsonpath-mapper');
|
|
12
12
|
require('await-to-js');
|
|
@@ -19,9 +19,6 @@ const loginUser = (username, password) => selectors.action(reducers.LOGIN_USER,
|
|
|
19
19
|
username,
|
|
20
20
|
password
|
|
21
21
|
});
|
|
22
|
-
const verifyTwoFa = twoFaToken => selectors.action(reducers.VERIFY_TWO_FA_TOKEN, {
|
|
23
|
-
twoFaToken
|
|
24
|
-
});
|
|
25
22
|
const logoutUser = redirectPath => selectors.action(reducers.LOGOUT_USER, {
|
|
26
23
|
redirectPath
|
|
27
24
|
});
|
|
@@ -44,7 +41,6 @@ const changePassword = (userId, currentPassword, newPassword) => selectors.actio
|
|
|
44
41
|
var actions = /*#__PURE__*/Object.freeze({
|
|
45
42
|
__proto__: null,
|
|
46
43
|
loginUser: loginUser,
|
|
47
|
-
verifyTwoFa: verifyTwoFa,
|
|
48
44
|
logoutUser: logoutUser,
|
|
49
45
|
registerUser: registerUser,
|
|
50
46
|
requestPasswordReset: requestPasswordReset,
|
|
@@ -57,10 +53,8 @@ const useLogin = () => {
|
|
|
57
53
|
const select = reactRedux.useSelector;
|
|
58
54
|
return {
|
|
59
55
|
loginUser: (username, password) => dispatch(loginUser(username, password)),
|
|
60
|
-
verifyTwoFa: twoFaToken => dispatch(verifyTwoFa(twoFaToken)),
|
|
61
56
|
logoutUser: redirectPath => dispatch(logoutUser(redirectPath)),
|
|
62
57
|
errorMessage: select(ToJs.selectUserErrorMessage),
|
|
63
|
-
requiresTwoFa: select(ToJs.selectUserRequiresTwoFa),
|
|
64
58
|
isAuthenticated: select(ToJs.selectUserIsAuthenticated),
|
|
65
59
|
isAuthenticationError: select(ToJs.selectUserIsAuthenticationError),
|
|
66
60
|
isError: select(ToJs.selectUserIsError),
|