@lifeready/core 6.1.3 → 6.1.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (75) hide show
  1. package/bundles/lifeready-core.umd.js +301 -293
  2. package/bundles/lifeready-core.umd.js.map +1 -1
  3. package/bundles/lifeready-core.umd.min.js +1 -1
  4. package/bundles/lifeready-core.umd.min.js.map +1 -1
  5. package/esm2015/lib/auth/auth.config.js +57 -0
  6. package/esm2015/lib/auth/auth.gql.private.js +85 -0
  7. package/esm2015/lib/auth/auth.service.js +602 -0
  8. package/esm2015/lib/auth/auth.types.js +21 -0
  9. package/esm2015/lib/item/item.gql.js +164 -0
  10. package/esm2015/lib/item/item.gql.private.js +23 -0
  11. package/esm2015/lib/item/item.service.js +592 -0
  12. package/esm2015/lib/item/item.types.js +2 -0
  13. package/esm2015/lib/key-exchange/key-exchange.gql.js +174 -0
  14. package/esm2015/lib/key-exchange/key-exchange.service.js +480 -0
  15. package/esm2015/lib/lbop/lbop.service.js +7 -15
  16. package/esm2015/lib/life-ready.module.js +2 -2
  17. package/esm2015/lib/password/password.service.js +1 -1
  18. package/esm2015/lib/plan/plan.gql.js +91 -0
  19. package/esm2015/lib/plan/plan.service.js +191 -0
  20. package/esm2015/lib/plan/plan.types.js +2 -0
  21. package/esm2015/lib/profile/profile.gql.js +2 -2
  22. package/esm2015/lib/profile/profile.service.js +1 -8
  23. package/esm2015/lib/profile/profile.types.js +1 -8
  24. package/esm2015/lib/scenario/scenario.service.js +8 -8
  25. package/esm2015/lib/shared-contact-card/shared-contact-card2.service.js +1 -1
  26. package/esm2015/lib/trusted-party/trusted-party.gql.js +64 -0
  27. package/esm2015/lib/trusted-party/trusted-party.gql.private.js +25 -0
  28. package/esm2015/lib/trusted-party/trusted-party.service.js +240 -0
  29. package/esm2015/lib/trusted-party/trusted-party.types.js +2 -0
  30. package/esm2015/public-api.js +17 -12
  31. package/fesm2015/lifeready-core.js +189 -211
  32. package/fesm2015/lifeready-core.js.map +1 -1
  33. package/lib/{auth2/auth2.service.d.ts → auth/auth.service.d.ts} +2 -2
  34. package/lib/{item2/item2.service.d.ts → item/item.service.d.ts} +39 -39
  35. package/lib/key-exchange/{key-exchange2.service.d.ts → key-exchange.service.d.ts} +2 -2
  36. package/lib/lbop/lbop.service.d.ts +1 -5
  37. package/lib/password/password.service.d.ts +1 -1
  38. package/lib/{plan2/plan2.service.d.ts → plan/plan.service.d.ts} +20 -20
  39. package/lib/profile/profile.service.d.ts +1 -2
  40. package/lib/profile/profile.types.d.ts +2 -15
  41. package/lib/scenario/scenario.service.d.ts +3 -3
  42. package/lib/shared-contact-card/shared-contact-card2.service.d.ts +1 -1
  43. package/lib/trusted-party/{trusted-party2.service.d.ts → trusted-party.service.d.ts} +6 -6
  44. package/lifeready-core.metadata.json +1 -1
  45. package/package.json +1 -1
  46. package/public-api.d.ts +16 -11
  47. package/esm2015/lib/auth2/auth.config.js +0 -57
  48. package/esm2015/lib/auth2/auth2.gql.private.js +0 -85
  49. package/esm2015/lib/auth2/auth2.service.js +0 -602
  50. package/esm2015/lib/auth2/auth2.types.js +0 -21
  51. package/esm2015/lib/item2/item2.gql.js +0 -164
  52. package/esm2015/lib/item2/item2.gql.private.js +0 -23
  53. package/esm2015/lib/item2/item2.service.js +0 -592
  54. package/esm2015/lib/item2/item2.types.js +0 -2
  55. package/esm2015/lib/key-exchange/key-exchange2.gql.js +0 -174
  56. package/esm2015/lib/key-exchange/key-exchange2.service.js +0 -480
  57. package/esm2015/lib/plan2/plan2.gql.js +0 -91
  58. package/esm2015/lib/plan2/plan2.service.js +0 -191
  59. package/esm2015/lib/plan2/plan2.types.js +0 -2
  60. package/esm2015/lib/trusted-party/trusted-party2.gql.js +0 -64
  61. package/esm2015/lib/trusted-party/trusted-party2.gql.private.js +0 -25
  62. package/esm2015/lib/trusted-party/trusted-party2.service.js +0 -240
  63. package/esm2015/lib/trusted-party/trusted-party2.types.js +0 -2
  64. /package/lib/{auth2 → auth}/auth.config.d.ts +0 -0
  65. /package/lib/{auth2/auth2.gql.private.d.ts → auth/auth.gql.private.d.ts} +0 -0
  66. /package/lib/{auth2/auth2.types.d.ts → auth/auth.types.d.ts} +0 -0
  67. /package/lib/{item2/item2.gql.d.ts → item/item.gql.d.ts} +0 -0
  68. /package/lib/{item2/item2.gql.private.d.ts → item/item.gql.private.d.ts} +0 -0
  69. /package/lib/{item2/item2.types.d.ts → item/item.types.d.ts} +0 -0
  70. /package/lib/key-exchange/{key-exchange2.gql.d.ts → key-exchange.gql.d.ts} +0 -0
  71. /package/lib/{plan2/plan2.gql.d.ts → plan/plan.gql.d.ts} +0 -0
  72. /package/lib/{plan2/plan2.types.d.ts → plan/plan.types.d.ts} +0 -0
  73. /package/lib/trusted-party/{trusted-party2.gql.d.ts → trusted-party.gql.d.ts} +0 -0
  74. /package/lib/trusted-party/{trusted-party2.gql.private.d.ts → trusted-party.gql.private.d.ts} +0 -0
  75. /package/lib/trusted-party/{trusted-party2.types.d.ts → trusted-party.types.d.ts} +0 -0
@@ -1,602 +0,0 @@
1
- var Auth2Service_1;
2
- import { __awaiter, __decorate } from "tslib";
3
- import { HttpClient } from '@angular/common/http';
4
- import { Inject, Injectable, Injector, isDevMode, NgZone } from '@angular/core';
5
- import { AuthClass } from '@aws-amplify/auth/lib-esm/Auth';
6
- import { Hub } from '@aws-amplify/core';
7
- import { JWK } from 'node-jose';
8
- import { LrGraphQLService, LrMutation, LrService } from '../api/lr-graphql';
9
- import { TpClaimState } from '../api/types';
10
- import { EncryptionService } from '../encryption/encryption.service';
11
- import { IdleService } from '../idle/idle.service';
12
- import { KeyFactoryService } from '../key/key-factory.service';
13
- import { KeyGraphService } from '../key/key-graph.service';
14
- import { KeyService } from '../key/key.service';
15
- import { KC_CONFIG } from '../life-ready.config';
16
- import { PasswordService } from '../password/password.service';
17
- import { PersistService } from '../persist/persist.service';
18
- import { TP_PASSWORD_RESET_CLIENT_NONCE_LENGTH, TP_PASSWORD_RESET_USERNAME_SUFFIX, } from '../tp-password-reset/tp-password-reset.constants';
19
- import { TpPasswordResetAssemblyController } from '../tp-password-reset/tp-password-reset.controller';
20
- import { CompleteTpPasswordResetRequestMutation, CreateTpAssemblyKeyChallengeMutation, PreCompleteTpPasswordResetRequestMutation, } from '../tp-password-reset/tp-password-reset.gql';
21
- import { KcBadRequestException, KcBadStateException, KcConcurrentAccessException, KcInternalErrorException, } from '../_common/exceptions';
22
- import { KeyContainer } from '../_common/key';
23
- import { RunOutsideAngular } from '../_common/run-outside-angular';
24
- import { CurrentUserQuery, ResetUserQuery, SetSessionEncryptionKeyMutation, } from './auth2.gql.private';
25
- import { CognitoChallengeName, PasswordChangeStatus, RecoveryStatus, } from './auth2.types';
26
- import * as i0 from "@angular/core";
27
- import * as i1 from "@angular/common/http";
28
- import * as i2 from "@aws-amplify/auth/lib-esm/Auth";
29
- import * as i3 from "../api/lr-graphql/lr-graphql.service";
30
- import * as i4 from "../key/key.service";
31
- import * as i5 from "../key/key-graph.service";
32
- import * as i6 from "../key/key-factory.service";
33
- import * as i7 from "../password/password.service";
34
- import * as i8 from "../idle/idle.service";
35
- import * as i9 from "../persist/persist.service";
36
- import * as i10 from "../encryption/encryption.service";
37
- import * as i11 from "../tp-password-reset/tp-password-reset.controller";
38
- import * as i12 from "../life-ready.config";
39
- let Auth2Service = Auth2Service_1 = class Auth2Service extends LrService {
40
- constructor(ngZone, injector, http, cognito, api, keyService, keyGraphService, keyFactoryService, passwordService, idleService, persistService, encryptionService, assemblyController, kcConfig) {
41
- super(injector);
42
- this.ngZone = ngZone;
43
- this.injector = injector;
44
- this.http = http;
45
- this.cognito = cognito;
46
- this.api = api;
47
- this.keyService = keyService;
48
- this.keyGraphService = keyGraphService;
49
- this.keyFactoryService = keyFactoryService;
50
- this.passwordService = passwordService;
51
- this.idleService = idleService;
52
- this.persistService = persistService;
53
- this.encryptionService = encryptionService;
54
- this.assemblyController = assemblyController;
55
- this.kcConfig = kcConfig;
56
- // Could use rxjs observables here. But trying to have kc-client use as little angular
57
- // features as possible. Rxjs is not used anywhere else in kc-client.
58
- this.logoutListeners = new Set();
59
- // Stores the password for use after mfa verification to decrypt masterKey.
60
- this.password = null;
61
- if (!isDevMode()) {
62
- if (this.kcConfig.debug != null) {
63
- throw new KcBadRequestException('In production mode, "KcConfig.debug" must be set to null');
64
- }
65
- }
66
- }
67
- importPassword(plainPassword) {
68
- return this.keyFactoryService.importPassword(plainPassword);
69
- }
70
- logout() {
71
- var _a;
72
- return __awaiter(this, void 0, void 0, function* () {
73
- // Notify all listeners to clean up.
74
- yield Promise.all([...this.logoutListeners].map((callback) => callback()));
75
- this.user = null;
76
- this.keyService.purgeKeys();
77
- this.keyGraphService.purgeKeys();
78
- // Sign out on both cognito and kc-server
79
- yield Promise.all([this.cognito.signOut(), this.kcLogout()]);
80
- if ((_a = this.kcConfig.debug) === null || _a === void 0 ? void 0 : _a.username) {
81
- this.kcConfig.debug.username = null;
82
- }
83
- });
84
- }
85
- addLogoutListener(callback) {
86
- this.logoutListeners.add(callback);
87
- }
88
- removeLogoutListener(callback) {
89
- this.logoutListeners.delete(callback);
90
- }
91
- login(emailOrPhone, password, { tpPasswordResetAutoComplete = true } = {}) {
92
- var _a;
93
- return __awaiter(this, void 0, void 0, function* () {
94
- let loginResult = yield this.loginImpl(emailOrPhone, password);
95
- // Save the password for use after meeting challenge.
96
- if (loginResult.challenge) {
97
- this.password = new KeyContainer(password, Auth2Service_1.CHALLENGE_TIMEOUT);
98
- return loginResult;
99
- }
100
- if (tpPasswordResetAutoComplete &&
101
- ((_a = loginResult.user.resetUser) === null || _a === void 0 ? void 0 : _a.state) === TpClaimState.APPROVED) {
102
- yield this.completeResetRequest(password);
103
- loginResult = yield this.loginImpl(emailOrPhone, password);
104
- }
105
- return loginResult;
106
- });
107
- }
108
- verifyLogin(options) {
109
- return __awaiter(this, void 0, void 0, function* () {
110
- const { challenge, code, rememberMe } = options;
111
- const VALID_CHALLENGE_NAMES = [
112
- CognitoChallengeName.SMS_MFA,
113
- CognitoChallengeName.SOFTWARE_TOKEN_MFA,
114
- ];
115
- if (!VALID_CHALLENGE_NAMES.includes(challenge.cognitoUser.challengeName)) {
116
- throw new KcBadRequestException(`challengeName must be one of ${VALID_CHALLENGE_NAMES}`);
117
- }
118
- // TODO: this.auth.confirmSignIn() could return another challenge.
119
- const cognitoUser = yield this.cognito.confirmSignIn(challenge.cognitoUser, code, challenge.cognitoUser.challengeName);
120
- yield this.handlePostAuth(challenge.recoveryStatus);
121
- const user = yield this.loadUser(cognitoUser, this.password.pop());
122
- // This is not strictly necessary since the this.password.pop() already clears the
123
- // password inside the container. But doesn't hurt either.
124
- this.password = null;
125
- if (rememberMe) {
126
- cognitoUser.setDeviceStatusRemembered({
127
- onSuccess: () => {
128
- return;
129
- },
130
- onFailure: (e) => console.error(e),
131
- });
132
- }
133
- return {
134
- user,
135
- };
136
- });
137
- }
138
- getUser() {
139
- return __awaiter(this, void 0, void 0, function* () {
140
- if (this.user) {
141
- return this.user;
142
- }
143
- const cognitoUser = yield this.cognito.currentAuthenticatedUser();
144
- return this.loadUser(cognitoUser);
145
- });
146
- }
147
- refreshAccessToken() {
148
- return __awaiter(this, void 0, void 0, function* () {
149
- const cognitoUser = yield this.cognito.currentAuthenticatedUser();
150
- const refreshToken = cognitoUser.getSignInUserSession().getRefreshToken();
151
- console.log('Token refresh...');
152
- return new Promise((resolve, reject) => {
153
- cognitoUser.refreshSession(refreshToken, (err) => {
154
- if (err) {
155
- console.error('Error refreshing token: ', err);
156
- reject(err);
157
- }
158
- else {
159
- console.log('Token refresh complete');
160
- resolve(0);
161
- }
162
- });
163
- });
164
- });
165
- }
166
- // ----------------------------------------------------------------------------------------------------
167
- // Helpers
168
- // ----------------------------------------------------------------------------------------------------
169
- fetchCurrentUser() {
170
- return __awaiter(this, void 0, void 0, function* () {
171
- return (yield this.api.query({
172
- query: CurrentUserQuery,
173
- processorOptions: {
174
- hasKeys: false,
175
- },
176
- })).currentUser;
177
- });
178
- }
179
- fetchResetUser() {
180
- return __awaiter(this, void 0, void 0, function* () {
181
- return (yield this.api.query({
182
- query: ResetUserQuery,
183
- processorOptions: {
184
- hasKeys: false,
185
- },
186
- })).tpPasswordResetUser;
187
- });
188
- }
189
- kcLogout() {
190
- return __awaiter(this, void 0, void 0, function* () {
191
- yield this.http
192
- .post(`${this.kcConfig.authUrl}auth/sign-out/`, null, {
193
- withCredentials: true,
194
- responseType: 'text',
195
- })
196
- .toPromise();
197
- });
198
- }
199
- fetchPassIdpParams(emailOrPhone) {
200
- return __awaiter(this, void 0, void 0, function* () {
201
- return yield this.http
202
- .get(`${this.kcConfig.authUrl}users/pass-idp-params/?login_name=${encodeURIComponent(emailOrPhone)}`)
203
- .toPromise();
204
- });
205
- }
206
- loginImpl(emailOrPhone, password) {
207
- return __awaiter(this, void 0, void 0, function* () {
208
- yield this.logout();
209
- const loginIdpResult = yield this.loginIdp(emailOrPhone, password);
210
- // Can't get the user yet because we still ned to meet MFA challenges
211
- if ([
212
- CognitoChallengeName.SMS_MFA,
213
- CognitoChallengeName.SOFTWARE_TOKEN_MFA,
214
- ].includes(loginIdpResult.cognitoUser.challengeName)) {
215
- return {
216
- challenge: {
217
- cognitoUser: loginIdpResult.cognitoUser,
218
- recoveryStatus: loginIdpResult.recoveryStatus,
219
- },
220
- };
221
- }
222
- yield this.handlePostAuth(loginIdpResult.recoveryStatus);
223
- // There should be no MFA on the TP reset user.
224
- const user = yield this.loadUser(loginIdpResult.cognitoUser, password);
225
- return {
226
- user,
227
- };
228
- });
229
- }
230
- loginIdp(emailOrPhone, password) {
231
- return __awaiter(this, void 0, void 0, function* () {
232
- // Download the salt needed to derive the PassIdp
233
- const passIdpApiResult = yield this.fetchPassIdpParams(emailOrPhone);
234
- if (passIdpApiResult.passwordChangeStatus === PasswordChangeStatus.IN_PROGRESS) {
235
- throw new KcConcurrentAccessException('A password change is in progress');
236
- }
237
- if (passIdpApiResult.passwordChangeStatus === PasswordChangeStatus.RECOVERY) {
238
- console.log('In recovery mode.');
239
- // Let's say we don't know if the password is the new one or the old one. We just have to try both.
240
- try {
241
- const user = {
242
- cognitoUser: yield this.loginIdpImpl(emailOrPhone, password, passIdpApiResult.newPassIdpParams),
243
- recoveryStatus: RecoveryStatus.NEW_PASSWORD,
244
- };
245
- // New password worked. Let's set to the current password
246
- // --Potential Failure Point 1--
247
- // if changePasswordComplete() doesn't get called, then it should remain
248
- console.log('New password works!');
249
- return user;
250
- }
251
- catch (error) {
252
- // Just bubble up any other type of error.
253
- if (error.code !== 'NotAuthorizedException') {
254
- throw error;
255
- }
256
- // pass, try again assuming it's the old password
257
- }
258
- // Now assume it's the previous password. Any exception is allowed to bubble up.
259
- try {
260
- const user = {
261
- cognitoUser: yield this.loginIdpImpl(emailOrPhone, password, passIdpApiResult.currentPassIdpParams),
262
- recoveryStatus: RecoveryStatus.OLD_PASSWORD,
263
- };
264
- // Old password worked.
265
- console.log('Old password works!');
266
- return user;
267
- }
268
- catch (error) {
269
- // Just bubble up any other type of error.
270
- throw error.code === 'NotAuthorizedException'
271
- ? new KcBadRequestException('The password change request was interrupted, please try to login with both your new and old password')
272
- : error;
273
- }
274
- }
275
- // Try again as the TP password reset account
276
- if (passIdpApiResult.tpPasswordReset) {
277
- try {
278
- // TP password reset is in process. We need to try the password against both
279
- // original account and the new reset account.
280
- const reset = passIdpApiResult.tpPasswordReset;
281
- const user = {
282
- cognitoUser: yield this.loginIdpImpl(reset.resetUsername, password, reset.passIdpParams),
283
- recoveryStatus: RecoveryStatus.NONE,
284
- };
285
- return user;
286
- }
287
- catch (err) {
288
- // continue, try again as regular user.
289
- }
290
- }
291
- // Login as regular user
292
- const user = {
293
- cognitoUser: yield this.loginIdpImpl(emailOrPhone, password, passIdpApiResult.currentPassIdpParams),
294
- recoveryStatus: RecoveryStatus.NONE,
295
- };
296
- return user;
297
- });
298
- }
299
- loginIdpImpl(emailOrPhone, password, passIdpParams) {
300
- return __awaiter(this, void 0, void 0, function* () {
301
- const passIdpResult = yield this.keyFactoryService.derivePassIdp(Object.assign({ password }, passIdpParams));
302
- // Use the derived password to signin with cognito
303
- return this.cognito.signIn(emailOrPhone, this.passwordService.getPassIdpString(passIdpResult.jwk));
304
- });
305
- }
306
- handlePostAuth(recoveryStatus) {
307
- return __awaiter(this, void 0, void 0, function* () {
308
- yield this.handlePasswordRecovery(recoveryStatus);
309
- yield this.handleSessionEncryptionKey();
310
- });
311
- }
312
- handlePasswordRecovery(recoveryStatus) {
313
- return __awaiter(this, void 0, void 0, function* () {
314
- if (recoveryStatus !== RecoveryStatus.NONE) {
315
- yield this.passwordService.changePasswordComplete({
316
- useNewPassword: recoveryStatus === RecoveryStatus.NEW_PASSWORD,
317
- });
318
- }
319
- });
320
- }
321
- handleSessionEncryptionKey() {
322
- return __awaiter(this, void 0, void 0, function* () {
323
- if (this.kcConfig.disableSessionEncryptionKey) {
324
- if (!isDevMode()) {
325
- const msg = 'You should not set disableSessionEncryptionKey=True in mode prod. It defaults to false.';
326
- console.error(msg);
327
- throw new KcInternalErrorException(msg);
328
- }
329
- else {
330
- console.warn('You have set disableSessionEncryptionKey=True. Make sure not to do this in prod mode.');
331
- }
332
- }
333
- else {
334
- // Set the session key to a new encryption key for this session
335
- const sessionEncryptionKey = yield this.keyFactoryService.createKey();
336
- yield this.lrGraphQL.lrMutate(new LrMutation({
337
- mutation: SetSessionEncryptionKeyMutation,
338
- variables: {
339
- input: {
340
- sessionEncryptionKey: JSON.stringify(sessionEncryptionKey.toJSON(true)),
341
- },
342
- },
343
- }), {
344
- includeKeyGraph: false,
345
- });
346
- this.persistService.setServerSessionEncryptionKey(sessionEncryptionKey);
347
- }
348
- });
349
- }
350
- getCognitoUserAttribute(attributeName, userAttributes) {
351
- const userAttribute = userAttributes.find((x) => x.getName() === attributeName);
352
- return userAttribute ? userAttribute.getValue() : null;
353
- }
354
- loadUserKeys(options) {
355
- return __awaiter(this, void 0, void 0, function* () {
356
- const { userKeys, password, sessionEncryptionKey } = options;
357
- if (sessionEncryptionKey) {
358
- this.persistService.setServerSessionEncryptionKey(yield JWK.asKey(sessionEncryptionKey));
359
- }
360
- // password is not needed if the master key is already persisted.
361
- if (password) {
362
- const passKey = (yield this.keyFactoryService.derivePassKey(Object.assign({ password }, userKeys.passKey.passKeyParams))).jwk;
363
- yield this.idleService.persistMasterKey(yield this.keyGraphService.unwrapWithPassKey(userKeys.passKey.id, passKey, userKeys.masterKey.id));
364
- }
365
- });
366
- }
367
- loadUser(cognitoUser, password) {
368
- return __awaiter(this, void 0, void 0, function* () {
369
- if (cognitoUser.getUsername().endsWith(TP_PASSWORD_RESET_USERNAME_SUFFIX)) {
370
- this.user = yield this.loadResetUser(cognitoUser, password);
371
- }
372
- else {
373
- this.user = yield this.loadRegularUser(cognitoUser, password);
374
- }
375
- yield this.idleService.start(); // Run idleService whenever user is logged in.
376
- return this.user;
377
- });
378
- }
379
- loadRegularUser(cognitoUser, password) {
380
- return __awaiter(this, void 0, void 0, function* () {
381
- const currentUser = yield this.fetchCurrentUser();
382
- yield this.loadUserKeys({
383
- userKeys: currentUser.currentUserKey,
384
- password,
385
- sessionEncryptionKey: currentUser.sessionEncryptionKey,
386
- });
387
- // Regular user populates all keys
388
- yield this.keyGraphService.populateKeys(currentUser.currentUserKey);
389
- const { username } = currentUser;
390
- const userAttributes = yield this.cognito.userAttributes(cognitoUser);
391
- return {
392
- username,
393
- sub: this.getCognitoUserAttribute('sub', userAttributes),
394
- loginEmail: this.getCognitoUserAttribute('email', userAttributes),
395
- resetUser: null,
396
- };
397
- });
398
- }
399
- loadResetUser(cognitoUser, password) {
400
- return __awaiter(this, void 0, void 0, function* () {
401
- const resetUser = yield this.fetchResetUser();
402
- const userKeys = {
403
- passKey: {
404
- id: resetUser.passKey.id,
405
- passKeyParams: resetUser.passKey.passKeyParams,
406
- },
407
- masterKey: {
408
- id: resetUser.masterKey.id,
409
- },
410
- };
411
- yield this.loadUserKeys({
412
- userKeys,
413
- password,
414
- sessionEncryptionKey: resetUser.sessionEncryptionKey,
415
- });
416
- // Reset user only sets a subset of keys
417
- yield this.keyService.setKeys(userKeys);
418
- const { username } = resetUser;
419
- const userAttributes = yield this.cognito.userAttributes(cognitoUser);
420
- return {
421
- username,
422
- sub: this.getCognitoUserAttribute('sub', userAttributes),
423
- loginEmail: this.getCognitoUserAttribute('email', userAttributes),
424
- resetUser: {
425
- state: resetUser.state,
426
- },
427
- };
428
- });
429
- }
430
- recoverAssemblyKey(resetUser) {
431
- return __awaiter(this, void 0, void 0, function* () {
432
- const prk = yield this.keyGraphService.getKey(resetUser.pxk.id);
433
- const partials = yield Promise.all(resetUser.approvals
434
- .filter((approval) => !!approval.receiverCipherPartialAssemblyKey)
435
- .map((approval) => this.encryptionService.decrypt(prk, approval.receiverCipherPartialAssemblyKey)));
436
- return this.assemblyController.recoverAssemblyKey(partials);
437
- });
438
- }
439
- completeResetRequest(newPassword) {
440
- return __awaiter(this, void 0, void 0, function* () {
441
- const resetUser = yield this.fetchResetUser();
442
- if (resetUser.state !== TpClaimState.APPROVED) {
443
- throw new KcBadStateException('Password reset request has not been approved.');
444
- }
445
- // --------------------------------------------------------------
446
- // Prepare all materials to ensure there are no errors.
447
- // --------------------------------------------------------------
448
- const assemblyKey = yield this.recoverAssemblyKey(resetUser);
449
- const { rootKey } = yield this.encryptionService.decrypt(assemblyKey, resetUser.assemblyCipherData);
450
- // Making sure it's a valid key.
451
- const rootKeyJwk = yield JWK.asKey(rootKey);
452
- const masterKey = yield this.keyGraphService.getKey(resetUser.masterKey.id);
453
- const masterKeyWrappedRootKey = yield this.encryptionService.encryptToString(masterKey.jwk, rootKeyJwk.toJSON(true));
454
- // The new password
455
- const newPassIdpResult = yield this.keyFactoryService.derivePassIdp(Object.assign({ password: newPassword }, resetUser.passKey.passIdpParams));
456
- const newIdpPassword = this.passwordService.getPassIdpString(newPassIdpResult.jwk);
457
- // --------------------------------------------------------------
458
- // Get assembly key challenge
459
- // --------------------------------------------------------------
460
- const challenge = (yield this.lrGraphQL.lrMutate(new LrMutation({
461
- mutation: CreateTpAssemblyKeyChallengeMutation,
462
- variables: {
463
- input: {},
464
- },
465
- }), {
466
- includeKeyGraph: false,
467
- })).createTpAssemblyKeyChallenge.challenge;
468
- // Sign the challenge
469
- // Generate a client side nonce that's no in the server's control.
470
- challenge.clientNonce = this.keyFactoryService.randomString(TP_PASSWORD_RESET_CLIENT_NONCE_LENGTH);
471
- const assemblyKeyVerifierPrk = yield this.encryptionService.decrypt(assemblyKey, resetUser.wrappedAssemblyKeyVerifierPrk);
472
- const signedChallenge = yield this.encryptionService.sign(assemblyKeyVerifierPrk, challenge);
473
- // --------------------------------------------------------------
474
- // Change password for the original user
475
- // --------------------------------------------------------------
476
- const tempIdpPassword = (yield this.lrGraphQL.lrMutate(new LrMutation({
477
- mutation: PreCompleteTpPasswordResetRequestMutation,
478
- variables: {
479
- input: {
480
- signedChallenge: JSON.stringify(signedChallenge),
481
- },
482
- },
483
- }), {
484
- includeKeyGraph: false,
485
- })).preCompleteTpPasswordResetRequest.idpPassword;
486
- // --------------------------------------------------------------
487
- // Login as the original user using new temporary password
488
- // --------------------------------------------------------------
489
- // At this point, the original account's password has been changed
490
- // to a temporary password. It is no longer possible for the user
491
- // to use the original password to login. Any successful login
492
- // can only be using the temporary password. So it's safe to assume
493
- // that we want to "complete" the password reset.
494
- // There maybe 2FA so we listen for the auth event from Amplify.
495
- const retPromise = new Promise((resolve) => {
496
- const listener = (data) => __awaiter(this, void 0, void 0, function* () {
497
- if (data.payload.event !== 'signIn') {
498
- return;
499
- }
500
- Hub.remove('auth', listener);
501
- yield this.cognito.signIn(resetUser.username, newIdpPassword);
502
- // Switch over to the new set of keys
503
- yield this.lrGraphQL.lrMutate(new LrMutation({
504
- mutation: CompleteTpPasswordResetRequestMutation,
505
- variables: {
506
- input: {
507
- masterKeyWrappedRootKey,
508
- masterKeyId: masterKey.id,
509
- },
510
- },
511
- }));
512
- resolve();
513
- });
514
- Hub.listen('auth', listener);
515
- });
516
- // Signin as the original user. Password has been reset to temporary one. It should return
517
- // with NEW_PASSWORD_REQUIRED
518
- let user = yield this.cognito.signIn(resetUser.username, tempIdpPassword, {
519
- noProxy: 'true',
520
- });
521
- if (user.challengeName !== 'NEW_PASSWORD_REQUIRED') {
522
- throw new KcInternalErrorException('Expecting Cognito to have done a password reset after call to PreCompleteTpPasswordResetRequestMutation.');
523
- }
524
- // Set new password on Idp
525
- // the awsFetch() function passes NEW_PASSWORD_REQUIRED directly to AWS without
526
- // going through the proxy.
527
- user = yield this.cognito.completeNewPassword(user, newIdpPassword, {});
528
- return retPromise;
529
- });
530
- }
531
- // ------------------------------------------------------
532
- // Debug utilities
533
- // ------------------------------------------------------
534
- debugLogin(username, password) {
535
- // This will fail if debug is null. But when debug is null, this function
536
- // should not be called.
537
- this.kcConfig.debug.username = username;
538
- return this.debugLoadUser(password);
539
- }
540
- debugLoadUser(password) {
541
- return __awaiter(this, void 0, void 0, function* () {
542
- const currentUser = yield this.fetchCurrentUser();
543
- const { username, currentUserKey } = currentUser;
544
- // Debug mode can not deal with session encryption key yet.
545
- // NO SESSION ENCRYPTION KEY.
546
- const passKey = (yield this.keyFactoryService.derivePassKey(Object.assign({ password }, currentUserKey.passKey.passKeyParams))).jwk;
547
- const masterKey = yield this.keyGraphService.unwrapWithPassKey(currentUserKey.passKey.id, passKey, currentUserKey.masterKey.id);
548
- yield this.idleService.persistMasterKey(masterKey);
549
- yield this.keyGraphService.populateKeys(currentUserKey);
550
- this.user = {
551
- username,
552
- resetUser: null,
553
- sub: 'DEBUG_MODE',
554
- loginEmail: 'DEBUG_MODE',
555
- };
556
- return this.user;
557
- });
558
- }
559
- /**
560
- * Clears the caches user. So we can simulate a page refresh and test getUser().
561
- */
562
- debugClearUser() {
563
- this.user = null;
564
- }
565
- getCurrentUserAttributes() {
566
- return __awaiter(this, void 0, void 0, function* () {
567
- const cognitoUser = yield this.cognito.currentAuthenticatedUser();
568
- const userAttributes = yield this.cognito.userAttributes(cognitoUser);
569
- return userAttributes;
570
- });
571
- }
572
- };
573
- Auth2Service.CHALLENGE_TIMEOUT = 1000 * 60 * 5;
574
- Auth2Service.ɵprov = i0.ɵɵdefineInjectable({ factory: function Auth2Service_Factory() { return new Auth2Service(i0.ɵɵinject(i0.NgZone), i0.ɵɵinject(i0.INJECTOR), i0.ɵɵinject(i1.HttpClient), i0.ɵɵinject(i2.AuthClass), i0.ɵɵinject(i3.LrGraphQLService), i0.ɵɵinject(i4.KeyService), i0.ɵɵinject(i5.KeyGraphService), i0.ɵɵinject(i6.KeyFactoryService), i0.ɵɵinject(i7.PasswordService), i0.ɵɵinject(i8.IdleService), i0.ɵɵinject(i9.PersistService), i0.ɵɵinject(i10.EncryptionService), i0.ɵɵinject(i11.TpPasswordResetAssemblyController), i0.ɵɵinject(i12.KC_CONFIG)); }, token: Auth2Service, providedIn: "root" });
575
- Auth2Service.decorators = [
576
- { type: Injectable, args: [{
577
- providedIn: 'root',
578
- },] }
579
- ];
580
- Auth2Service.ctorParameters = () => [
581
- { type: NgZone },
582
- { type: Injector },
583
- { type: HttpClient },
584
- { type: AuthClass },
585
- { type: LrGraphQLService },
586
- { type: KeyService },
587
- { type: KeyGraphService },
588
- { type: KeyFactoryService },
589
- { type: PasswordService },
590
- { type: IdleService },
591
- { type: PersistService },
592
- { type: EncryptionService },
593
- { type: TpPasswordResetAssemblyController },
594
- { type: undefined, decorators: [{ type: Inject, args: [KC_CONFIG,] }] }
595
- ];
596
- Auth2Service = Auth2Service_1 = __decorate([
597
- RunOutsideAngular({
598
- ngZoneName: 'ngZone',
599
- })
600
- ], Auth2Service);
601
- export { Auth2Service };
602
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth2.service.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/auth2/auth2.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\nimport { Inject, Injectable, Injector, isDevMode, NgZone } from '@angular/core';\nimport { CognitoUser } from '@aws-amplify/auth';\nimport { AuthClass } from '@aws-amplify/auth/lib-esm/Auth';\nimport { Hub } from '@aws-amplify/core';\nimport { CognitoUserAttribute } from 'amazon-cognito-identity-js';\nimport { JWK } from 'node-jose';\nimport { LrGraphQLService, LrMutation, LrService } from '../api/lr-graphql';\nimport { TpClaimState } from '../api/types';\nimport { EncryptionService } from '../encryption/encryption.service';\nimport { IdleService } from '../idle/idle.service';\nimport { KeyFactoryService } from '../key/key-factory.service';\nimport { KeyGraphService } from '../key/key-graph.service';\nimport { KeyService, UserKeys } from '../key/key.service';\nimport { PassIdpParams } from '../key/key.types';\nimport { KcConfig, KC_CONFIG } from '../life-ready.config';\nimport { PasswordService } from '../password/password.service';\nimport { PersistService } from '../persist/persist.service';\nimport {\n  TP_PASSWORD_RESET_CLIENT_NONCE_LENGTH,\n  TP_PASSWORD_RESET_USERNAME_SUFFIX,\n} from '../tp-password-reset/tp-password-reset.constants';\nimport { TpPasswordResetAssemblyController } from '../tp-password-reset/tp-password-reset.controller';\nimport {\n  CompleteTpPasswordResetRequestMutation,\n  CreateTpAssemblyKeyChallengeMutation,\n  PreCompleteTpPasswordResetRequestMutation,\n} from '../tp-password-reset/tp-password-reset.gql';\nimport {\n  KcBadRequestException,\n  KcBadStateException,\n  KcConcurrentAccessException,\n  KcInternalErrorException,\n} from '../_common/exceptions';\nimport { KeyContainer } from '../_common/key';\nimport { RunOutsideAngular } from '../_common/run-outside-angular';\nimport {\n  CurrentUserQuery,\n  CurrentUserQueryResult,\n  ResetUserQuery,\n  ResetUserQueryResult,\n  SetSessionEncryptionKeyMutation,\n} from './auth2.gql.private';\nimport {\n  AuthUser,\n  CognitoChallengeName,\n  LoginChallenge,\n  LoginOptions,\n  LoginResult,\n  LogoutListener,\n  LrCognitoUser,\n  LrCognitoUserAttribute,\n  PassIdpResult,\n  PasswordChangeStatus,\n  RecoveryStatus,\n} from './auth2.types';\n\n@RunOutsideAngular({\n  ngZoneName: 'ngZone',\n})\n@Injectable({\n  providedIn: 'root',\n})\nexport class Auth2Service extends LrService {\n  static CHALLENGE_TIMEOUT = 1000 * 60 * 5;\n\n  // Could use rxjs observables here. But trying to have kc-client use as little angular\n  // features as possible. Rxjs is not used anywhere else in kc-client.\n  private logoutListeners = new Set<LogoutListener>();\n  private user: AuthUser;\n  // Stores the password for use after mfa verification to decrypt masterKey.\n  private password: KeyContainer = null;\n\n  constructor(\n    private ngZone: NgZone,\n    private injector: Injector,\n    private http: HttpClient,\n    private cognito: AuthClass,\n    private api: LrGraphQLService,\n    private keyService: KeyService,\n    private keyGraphService: KeyGraphService,\n    private keyFactoryService: KeyFactoryService,\n    private passwordService: PasswordService,\n    private idleService: IdleService,\n    private persistService: PersistService,\n    private encryptionService: EncryptionService,\n    private assemblyController: TpPasswordResetAssemblyController,\n    @Inject(KC_CONFIG) private kcConfig: KcConfig\n  ) {\n    super(injector);\n    if (!isDevMode()) {\n      if (this.kcConfig.debug != null) {\n        throw new KcBadRequestException(\n          'In production mode, \"KcConfig.debug\" must be set to null'\n        );\n      }\n    }\n  }\n\n  importPassword(plainPassword: string): Promise<CryptoKey> {\n    return this.keyFactoryService.importPassword(plainPassword);\n  }\n\n  async logout(): Promise<void> {\n    // Notify all listeners to clean up.\n    await Promise.all([...this.logoutListeners].map((callback) => callback()));\n\n    this.user = null;\n    this.keyService.purgeKeys();\n    this.keyGraphService.purgeKeys();\n\n    // Sign out on both cognito and kc-server\n    await Promise.all([this.cognito.signOut(), this.kcLogout()]);\n\n    if (this.kcConfig.debug?.username) {\n      this.kcConfig.debug.username = null;\n    }\n  }\n\n  addLogoutListener(callback: LogoutListener) {\n    this.logoutListeners.add(callback);\n  }\n\n  removeLogoutListener(callback: LogoutListener) {\n    this.logoutListeners.delete(callback);\n  }\n\n  async login(\n    emailOrPhone: string,\n    password: CryptoKey,\n    { tpPasswordResetAutoComplete = true }: LoginOptions = {}\n  ): Promise<LoginResult> {\n    let loginResult: LoginResult = await this.loginImpl(emailOrPhone, password);\n\n    // Save the password for use after meeting challenge.\n    if (loginResult.challenge) {\n      this.password = new KeyContainer(\n        password,\n        Auth2Service.CHALLENGE_TIMEOUT\n      );\n\n      return loginResult;\n    }\n\n    if (\n      tpPasswordResetAutoComplete &&\n      loginResult.user.resetUser?.state === TpClaimState.APPROVED\n    ) {\n      await this.completeResetRequest(password);\n      loginResult = await this.loginImpl(emailOrPhone, password);\n    }\n\n    return loginResult;\n  }\n\n  async verifyLogin(options: {\n    challenge: LoginChallenge;\n    code: string;\n    rememberMe: boolean;\n  }): Promise<LoginResult> {\n    const { challenge, code, rememberMe } = options;\n\n    const VALID_CHALLENGE_NAMES = [\n      CognitoChallengeName.SMS_MFA,\n      CognitoChallengeName.SOFTWARE_TOKEN_MFA,\n    ];\n\n    if (!VALID_CHALLENGE_NAMES.includes(challenge.cognitoUser.challengeName)) {\n      throw new KcBadRequestException(\n        `challengeName must be one of ${VALID_CHALLENGE_NAMES}`\n      );\n    }\n\n    // TODO: this.auth.confirmSignIn() could return another challenge.\n    const cognitoUser = await this.cognito.confirmSignIn(\n      challenge.cognitoUser,\n      code,\n      challenge.cognitoUser.challengeName as\n        | CognitoChallengeName.SMS_MFA\n        | CognitoChallengeName.SOFTWARE_TOKEN_MFA\n    );\n\n    await this.handlePostAuth(challenge.recoveryStatus);\n\n    const user = await this.loadUser(cognitoUser, this.password.pop());\n\n    // This is not strictly necessary since the this.password.pop() already clears the\n    // password inside the container. But doesn't hurt either.\n    this.password = null;\n\n    if (rememberMe) {\n      cognitoUser.setDeviceStatusRemembered({\n        onSuccess: () => {\n          return;\n        },\n        onFailure: (e) => console.error(e),\n      });\n    }\n\n    return {\n      user,\n    };\n  }\n\n  async getUser(): Promise<AuthUser> {\n    if (this.user) {\n      return this.user;\n    }\n\n    const cognitoUser = await this.cognito.currentAuthenticatedUser();\n\n    return this.loadUser(cognitoUser);\n  }\n\n  async refreshAccessToken() {\n    const cognitoUser: CognitoUser =\n      await this.cognito.currentAuthenticatedUser();\n    const refreshToken = cognitoUser.getSignInUserSession().getRefreshToken();\n\n    console.log('Token refresh...');\n    return new Promise((resolve, reject) => {\n      cognitoUser.refreshSession(refreshToken, (err) => {\n        if (err) {\n          console.error('Error refreshing token: ', err);\n          reject(err);\n        } else {\n          console.log('Token refresh complete');\n          resolve(0);\n        }\n      });\n    });\n  }\n\n  // ----------------------------------------------------------------------------------------------------\n  // Helpers\n  // ----------------------------------------------------------------------------------------------------\n\n  private async fetchCurrentUser() {\n    return (\n      await this.api.query<CurrentUserQueryResult>({\n        query: CurrentUserQuery,\n        processorOptions: {\n          hasKeys: false, // Don't try to decrypt anything because keys have not been setup yet\n        },\n      })\n    ).currentUser;\n  }\n\n  private async fetchResetUser() {\n    return (\n      await this.api.query<ResetUserQueryResult>({\n        query: ResetUserQuery,\n        processorOptions: {\n          hasKeys: false, // Don't try to decrypt anything because keys have not been setup yet\n        },\n      })\n    ).tpPasswordResetUser;\n  }\n\n  private async kcLogout(): Promise<void> {\n    await this.http\n      .post(`${this.kcConfig.authUrl}auth/sign-out/`, null, {\n        withCredentials: true,\n        responseType: 'text',\n      })\n      .toPromise();\n  }\n\n  private async fetchPassIdpParams(\n    emailOrPhone: string\n  ): Promise<PassIdpResult> {\n    return await this.http\n      .get<PassIdpResult>(\n        `${\n          this.kcConfig.authUrl\n        }users/pass-idp-params/?login_name=${encodeURIComponent(emailOrPhone)}`\n      )\n      .toPromise();\n  }\n\n  private async loginImpl(\n    emailOrPhone: string,\n    password: CryptoKey\n  ): Promise<LoginResult> {\n    await this.logout();\n    const loginIdpResult = await this.loginIdp(emailOrPhone, password);\n\n    // Can't get the user yet because we still ned to meet MFA challenges\n    if (\n      [\n        CognitoChallengeName.SMS_MFA,\n        CognitoChallengeName.SOFTWARE_TOKEN_MFA,\n      ].includes(loginIdpResult.cognitoUser.challengeName)\n    ) {\n      return {\n        challenge: {\n          cognitoUser: loginIdpResult.cognitoUser,\n          recoveryStatus: loginIdpResult.recoveryStatus,\n        },\n      };\n    }\n\n    await this.handlePostAuth(loginIdpResult.recoveryStatus);\n    // There should be no MFA on the TP reset user.\n    const user = await this.loadUser(loginIdpResult.cognitoUser, password);\n\n    return {\n      user,\n    };\n  }\n\n  private async loginIdp(\n    emailOrPhone: string,\n    password: CryptoKey\n  ): Promise<LoginChallenge> {\n    // Download the salt needed to derive the PassIdp\n    const passIdpApiResult = await this.fetchPassIdpParams(emailOrPhone);\n\n    if (\n      passIdpApiResult.passwordChangeStatus === PasswordChangeStatus.IN_PROGRESS\n    ) {\n      throw new KcConcurrentAccessException('A password change is in progress');\n    }\n\n    if (\n      passIdpApiResult.passwordChangeStatus === PasswordChangeStatus.RECOVERY\n    ) {\n      console.log('In recovery mode.');\n\n      // Let's say we don't know if the password is the new one or the old one. We just have to try both.\n      try {\n        const user: LoginChallenge = {\n          cognitoUser: await this.loginIdpImpl(\n            emailOrPhone,\n            password,\n            passIdpApiResult.newPassIdpParams\n          ),\n          recoveryStatus: RecoveryStatus.NEW_PASSWORD,\n        };\n        // New password worked. Let's set to the current password\n\n        // --Potential Failure Point 1--\n        // if changePasswordComplete() doesn't get called, then it should remain\n\n        console.log('New password works!');\n\n        return user;\n      } catch (error) {\n        // Just bubble up any other type of error.\n        if (error.code !== 'NotAuthorizedException') {\n          throw error;\n        }\n        // pass, try again assuming it's the old password\n      }\n\n      // Now assume it's the previous password. Any exception is allowed to bubble up.\n      try {\n        const user: LoginChallenge = {\n          cognitoUser: await this.loginIdpImpl(\n            emailOrPhone,\n            password,\n            passIdpApiResult.currentPassIdpParams\n          ),\n          recoveryStatus: RecoveryStatus.OLD_PASSWORD,\n        };\n        // Old password worked.\n        console.log('Old password works!');\n\n        return user;\n      } catch (error) {\n        // Just bubble up any other type of error.\n        throw error.code === 'NotAuthorizedException'\n          ? new KcBadRequestException(\n              'The password change request was interrupted, please try to login with both your new and old password'\n            )\n          : error;\n      }\n    }\n\n    // Try again as the TP password reset account\n    if (passIdpApiResult.tpPasswordReset) {\n      try {\n        // TP password reset is in process. We need to try the password against both\n        // original account and the new reset account.\n        const reset = passIdpApiResult.tpPasswordReset;\n        const user: LoginChallenge = {\n          cognitoUser: await this.loginIdpImpl(\n            reset.resetUsername,\n            password,\n            reset.passIdpParams\n          ),\n          recoveryStatus: RecoveryStatus.NONE,\n        };\n\n        return user;\n      } catch (err) {\n        // continue, try again as regular user.\n      }\n    }\n\n    // Login as regular user\n    const user: LoginChallenge = {\n      cognitoUser: await this.loginIdpImpl(\n        emailOrPhone,\n        password,\n        passIdpApiResult.currentPassIdpParams\n      ),\n      recoveryStatus: RecoveryStatus.NONE,\n    };\n\n    return user;\n  }\n\n  private async loginIdpImpl(\n    emailOrPhone: string,\n    password: CryptoKey,\n    passIdpParams: PassIdpParams\n  ): Promise<LrCognitoUser> {\n    const passIdpResult = await this.keyFactoryService.derivePassIdp({\n      password,\n      ...passIdpParams,\n    });\n\n    // Use the derived password to signin with cognito\n    return this.cognito.signIn(\n      emailOrPhone,\n      this.passwordService.getPassIdpString(passIdpResult.jwk)\n    );\n  }\n\n  private async handlePostAuth(recoveryStatus: RecoveryStatus) {\n    await this.handlePasswordRecovery(recoveryStatus);\n    await this.handleSessionEncryptionKey();\n  }\n\n  private async handlePasswordRecovery(recoveryStatus: RecoveryStatus) {\n    if (recoveryStatus !== RecoveryStatus.NONE) {\n      await this.passwordService.changePasswordComplete({\n        useNewPassword: recoveryStatus === RecoveryStatus.NEW_PASSWORD,\n      });\n    }\n  }\n\n  private async handleSessionEncryptionKey() {\n    if (this.kcConfig.disableSessionEncryptionKey) {\n      if (!isDevMode()) {\n        const msg =\n          'You should not set disableSessionEncryptionKey=True in mode prod. It defaults to false.';\n        console.error(msg);\n        throw new KcInternalErrorException(msg);\n      } else {\n        console.warn(\n          'You have set disableSessionEncryptionKey=True. Make sure not to do this in prod mode.'\n        );\n      }\n    } else {\n      // Set the session key to a new encryption key for this session\n      const sessionEncryptionKey = await this.keyFactoryService.createKey();\n      await this.lrGraphQL.lrMutate(\n        new LrMutation({\n          mutation: SetSessionEncryptionKeyMutation,\n          variables: {\n            input: {\n              sessionEncryptionKey: JSON.stringify(\n                sessionEncryptionKey.toJSON(true)\n              ),\n            },\n          },\n        }),\n        {\n          includeKeyGraph: false,\n        }\n      );\n\n      this.persistService.setServerSessionEncryptionKey(sessionEncryptionKey);\n    }\n  }\n\n  private getCognitoUserAttribute(\n    attributeName: string,\n    userAttributes: CognitoUserAttribute[]\n  ) {\n    const userAttribute = userAttributes.find(\n      (x) => x.getName() === attributeName\n    );\n\n    return userAttribute ? userAttribute.getValue() : null;\n  }\n\n  private async loadUserKeys(options: {\n    userKeys: UserKeys;\n    password?: CryptoKey;\n    sessionEncryptionKey?: string;\n  }) {\n    const { userKeys, password, sessionEncryptionKey } = options;\n\n    if (sessionEncryptionKey) {\n      this.persistService.setServerSessionEncryptionKey(\n        await JWK.asKey(sessionEncryptionKey)\n      );\n    }\n\n    // password is not needed if the master key is already persisted.\n    if (password) {\n      const passKey = (\n        await this.keyFactoryService.derivePassKey({\n          password,\n          ...userKeys.passKey.passKeyParams,\n        })\n      ).jwk;\n\n      await this.idleService.persistMasterKey(\n        await this.keyGraphService.unwrapWithPassKey(\n          userKeys.passKey.id,\n          passKey,\n          userKeys.masterKey.id\n        )\n      );\n    }\n  }\n\n  private async loadUser(\n    cognitoUser: CognitoUser,\n    password?: CryptoKey\n  ): Promise<AuthUser> {\n    if (cognitoUser.getUsername().endsWith(TP_PASSWORD_RESET_USERNAME_SUFFIX)) {\n      this.user = await this.loadResetUser(cognitoUser, password);\n    } else {\n      this.user = await this.loadRegularUser(cognitoUser, password);\n    }\n\n    await this.idleService.start(); // Run idleService whenever user is logged in.\n\n    return this.user;\n  }\n\n  private async loadRegularUser(\n    cognitoUser: CognitoUser,\n    password?: CryptoKey\n  ): Promise<AuthUser> {\n    const currentUser = await this.fetchCurrentUser();\n\n    await this.loadUserKeys({\n      userKeys: currentUser.currentUserKey,\n      password,\n      sessionEncryptionKey: currentUser.sessionEncryptionKey,\n    });\n\n    // Regular user populates all keys\n    await this.keyGraphService.populateKeys(currentUser.currentUserKey);\n\n    const { username } = currentUser;\n    const userAttributes = await this.cognito.userAttributes(cognitoUser);\n\n    return {\n      username,\n      sub: this.getCognitoUserAttribute('sub', userAttributes),\n      loginEmail: this.getCognitoUserAttribute('email', userAttributes),\n      resetUser: null,\n    };\n  }\n\n  private async loadResetUser(\n    cognitoUser: CognitoUser,\n    password?: CryptoKey\n  ): Promise<AuthUser> {\n    const resetUser = await this.fetchResetUser();\n\n    const userKeys = {\n      passKey: {\n        id: resetUser.passKey.id,\n        passKeyParams: resetUser.passKey.passKeyParams,\n      },\n      masterKey: {\n        id: resetUser.masterKey.id,\n      },\n    };\n\n    await this.loadUserKeys({\n      userKeys,\n      password,\n      sessionEncryptionKey: resetUser.sessionEncryptionKey,\n    });\n\n    // Reset user only sets a subset of keys\n    await this.keyService.setKeys(userKeys);\n\n    const { username } = resetUser;\n    const userAttributes = await this.cognito.userAttributes(cognitoUser);\n\n    return {\n      username,\n      sub: this.getCognitoUserAttribute('sub', userAttributes),\n      loginEmail: this.getCognitoUserAttribute('email', userAttributes),\n      resetUser: {\n        state: resetUser.state,\n      },\n    };\n  }\n\n  private async recoverAssemblyKey(\n    resetUser: ResetUserQueryResult['tpPasswordResetUser']\n  ): Promise<JWK.Key> {\n    const prk = await this.keyGraphService.getKey(resetUser.pxk.id);\n\n    const partials = await Promise.all(\n      resetUser.approvals\n        .filter((approval) => !!approval.receiverCipherPartialAssemblyKey)\n        .map((approval) =>\n          this.encryptionService.decrypt(\n            prk,\n            approval.receiverCipherPartialAssemblyKey\n          )\n        )\n    );\n\n    return this.assemblyController.recoverAssemblyKey(partials);\n  }\n\n  async completeResetRequest(newPassword: CryptoKey): Promise<void> {\n    const resetUser = await this.fetchResetUser();\n\n    if (resetUser.state !== TpClaimState.APPROVED) {\n      throw new KcBadStateException(\n        'Password reset request has not been approved.'\n      );\n    }\n\n    // --------------------------------------------------------------\n    // Prepare all materials to ensure there are no errors.\n    // --------------------------------------------------------------\n    const assemblyKey = await this.recoverAssemblyKey(resetUser);\n\n    const { rootKey } = await this.encryptionService.decrypt(\n      assemblyKey,\n      resetUser.assemblyCipherData\n    );\n\n    // Making sure it's a valid key.\n    const rootKeyJwk = await JWK.asKey(rootKey);\n\n    const masterKey = await this.keyGraphService.getKey(resetUser.masterKey.id);\n\n    const masterKeyWrappedRootKey =\n      await this.encryptionService.encryptToString(\n        masterKey.jwk,\n        rootKeyJwk.toJSON(true)\n      );\n\n    // The new password\n    const newPassIdpResult = await this.keyFactoryService.derivePassIdp({\n      password: newPassword,\n      ...resetUser.passKey.passIdpParams,\n    });\n\n    const newIdpPassword = this.passwordService.getPassIdpString(\n      newPassIdpResult.jwk\n    );\n\n    // --------------------------------------------------------------\n    // Get assembly key challenge\n    // --------------------------------------------------------------\n    const challenge = (\n      await this.lrGraphQL.lrMutate(\n        new LrMutation({\n          mutation: CreateTpAssemblyKeyChallengeMutation,\n          variables: {\n            input: {},\n          },\n        }),\n        {\n          includeKeyGraph: false,\n        }\n      )\n    ).createTpAssemblyKeyChallenge.challenge;\n\n    // Sign the challenge\n    // Generate a client side nonce that's no in the server's control.\n    challenge.clientNonce = this.keyFactoryService.randomString(\n      TP_PASSWORD_RESET_CLIENT_NONCE_LENGTH\n    );\n\n    const assemblyKeyVerifierPrk = await this.encryptionService.decrypt(\n      assemblyKey,\n      resetUser.wrappedAssemblyKeyVerifierPrk\n    );\n    const signedChallenge = await this.encryptionService.sign(\n      assemblyKeyVerifierPrk,\n      challenge\n    );\n\n    // --------------------------------------------------------------\n    // Change password for the original user\n    // --------------------------------------------------------------\n    const tempIdpPassword = (\n      await this.lrGraphQL.lrMutate(\n        new LrMutation({\n          mutation: PreCompleteTpPasswordResetRequestMutation,\n          variables: {\n            input: {\n              signedChallenge: JSON.stringify(signedChallenge),\n            },\n          },\n        }),\n        {\n          includeKeyGraph: false,\n        }\n      )\n    ).preCompleteTpPasswordResetRequest.idpPassword;\n\n    // --------------------------------------------------------------\n    // Login as the original user using new temporary password\n    // --------------------------------------------------------------\n    // At this point, the original account's password has been changed\n    // to a temporary password. It is no longer possible for the user\n    // to use the original password to login. Any successful login\n    // can only be using the temporary password. So it's safe to assume\n    // that we want to \"complete\" the password reset.\n\n    // There maybe 2FA so we listen for the auth event from Amplify.\n    const retPromise = new Promise<void>((resolve) => {\n      const listener = async (data) => {\n        if (data.payload.event !== 'signIn') {\n          return;\n        }\n\n        Hub.remove('auth', listener);\n\n        await this.cognito.signIn(resetUser.username, newIdpPassword);\n\n        // Switch over to the new set of keys\n        await this.lrGraphQL.lrMutate(\n          new LrMutation({\n            mutation: CompleteTpPasswordResetRequestMutation,\n            variables: {\n              input: {\n                masterKeyWrappedRootKey,\n                masterKeyId: masterKey.id,\n              },\n            },\n          })\n        );\n\n        resolve();\n      };\n\n      Hub.listen('auth', listener);\n    });\n\n    // Signin as the original user. Password has been reset to temporary one. It should return\n    // with NEW_PASSWORD_REQUIRED\n    let user = await this.cognito.signIn(resetUser.username, tempIdpPassword, {\n      noProxy: 'true',\n    });\n\n    if (user.challengeName !== 'NEW_PASSWORD_REQUIRED') {\n      throw new KcInternalErrorException(\n        'Expecting Cognito to have done a password reset after call to PreCompleteTpPasswordResetRequestMutation.'\n      );\n    }\n\n    // Set new password on Idp\n    // the awsFetch() function passes NEW_PASSWORD_REQUIRED directly to AWS without\n    // going through the proxy.\n    user = await this.cognito.completeNewPassword(user, newIdpPassword, {});\n\n    return retPromise;\n  }\n\n  // ------------------------------------------------------\n  // Debug utilities\n  // ------------------------------------------------------\n  debugLogin(username: string, password: CryptoKey): Promise<AuthUser> {\n    // This will fail if debug is null. But when debug is null, this function\n    // should not be called.\n    this.kcConfig.debug.username = username;\n\n    return this.debugLoadUser(password);\n  }\n\n  private async debugLoadUser(password: CryptoKey): Promise<AuthUser> {\n    const currentUser = await this.fetchCurrentUser();\n\n    const { username, currentUserKey } = currentUser;\n\n    // Debug mode can not deal with session encryption key yet.\n    // NO SESSION ENCRYPTION KEY.\n\n    const passKey = (\n      await this.keyFactoryService.derivePassKey({\n        password,\n        ...currentUserKey.passKey.passKeyParams,\n      })\n    ).jwk;\n\n    const masterKey = await this.keyGraphService.unwrapWithPassKey(\n      currentUserKey.passKey.id,\n      passKey,\n      currentUserKey.masterKey.id\n    );\n\n    await this.idleService.persistMasterKey(masterKey);\n\n    await this.keyGraphService.populateKeys(currentUserKey);\n\n    this.user = {\n      username,\n      resetUser: null,\n      sub: 'DEBUG_MODE',\n      loginEmail: 'DEBUG_MODE',\n    };\n\n    return this.user;\n  }\n\n  /**\n   * Clears the caches user. So we can simulate a page refresh and test getUser().\n   */\n  debugClearUser() {\n    this.user = null;\n  }\n\n  async getCurrentUserAttributes(): Promise<LrCognitoUserAttribute[]> {\n    const cognitoUser = await this.cognito.currentAuthenticatedUser();\n    const userAttributes = await this.cognito.userAttributes(cognitoUser);\n\n    return userAttributes;\n  }\n}\n"]}