@lifeready/core 1.1.16 → 1.1.17
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/bundles/lifeready-core.umd.js +68 -40
- package/bundles/lifeready-core.umd.js.map +1 -1
- package/bundles/lifeready-core.umd.min.js +1 -1
- package/bundles/lifeready-core.umd.min.js.map +1 -1
- package/esm2015/lib/_common/storage.js +28 -0
- package/esm2015/lib/auth/life-ready-auth.service.js +4 -8
- package/esm2015/lib/tp-password-reset/tp-password-reset-user.service.js +5 -1
- package/esm2015/lifeready-core.js +8 -9
- package/fesm2015/lifeready-core.js +37 -9
- package/fesm2015/lifeready-core.js.map +1 -1
- package/lib/_common/storage.d.ts +13 -0
- package/lib/auth/life-ready-auth.service.d.ts +1 -3
- package/lifeready-core.d.ts +7 -8
- package/lifeready-core.metadata.json +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { LrBadArgumentException } from './exceptions';
|
|
2
|
+
const COGNITO_LOCALSTORAGE_PREFIX = 'CognitoIdentityServiceProvider';
|
|
3
|
+
/**
|
|
4
|
+
* Remove all keys in localstorage with matching prefix.
|
|
5
|
+
* A prefix must be specified. If you want to remove everything, then just use localStorage.clear().
|
|
6
|
+
*
|
|
7
|
+
* @param prefix Keys with this prefix will be removed.
|
|
8
|
+
*/
|
|
9
|
+
export function clearLocalStorage(prefix) {
|
|
10
|
+
if (!prefix) {
|
|
11
|
+
throw new LrBadArgumentException('You must specify a non empty prefix.');
|
|
12
|
+
}
|
|
13
|
+
// Remove all persisted session variables
|
|
14
|
+
Object.keys(localStorage).forEach((key) => {
|
|
15
|
+
if (key.startsWith(prefix)) {
|
|
16
|
+
localStorage.removeItem(key);
|
|
17
|
+
}
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* Clear all items related to cognito in localstorage.
|
|
22
|
+
* The remember device function sometimes interferes with creating new users
|
|
23
|
+
* on TP based password reset.
|
|
24
|
+
*/
|
|
25
|
+
export function clearCognitoLocalStorage() {
|
|
26
|
+
clearLocalStorage(COGNITO_LOCALSTORAGE_PREFIX);
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RvcmFnZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvc3JjL2xpYi9fY29tbW9uL3N0b3JhZ2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sY0FBYyxDQUFDO0FBRXRELE1BQU0sMkJBQTJCLEdBQUcsZ0NBQWdDLENBQUM7QUFFckU7Ozs7O0dBS0c7QUFDSCxNQUFNLFVBQVUsaUJBQWlCLENBQUMsTUFBYztJQUM5QyxJQUFJLENBQUMsTUFBTSxFQUFFO1FBQ1gsTUFBTSxJQUFJLHNCQUFzQixDQUFDLHNDQUFzQyxDQUFDLENBQUM7S0FDMUU7SUFFRCx5Q0FBeUM7SUFDekMsTUFBTSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRTtRQUN4QyxJQUFJLEdBQUcsQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLEVBQUU7WUFDMUIsWUFBWSxDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQUMsQ0FBQztTQUM5QjtJQUNILENBQUMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQztBQUVEOzs7O0dBSUc7QUFDSCxNQUFNLFVBQVUsd0JBQXdCO0lBQ3RDLGlCQUFpQixDQUFDLDJCQUEyQixDQUFDLENBQUM7QUFDakQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IExyQmFkQXJndW1lbnRFeGNlcHRpb24gfSBmcm9tICcuL2V4Y2VwdGlvbnMnO1xuXG5jb25zdCBDT0dOSVRPX0xPQ0FMU1RPUkFHRV9QUkVGSVggPSAnQ29nbml0b0lkZW50aXR5U2VydmljZVByb3ZpZGVyJztcblxuLyoqXG4gKiBSZW1vdmUgYWxsIGtleXMgaW4gbG9jYWxzdG9yYWdlIHdpdGggbWF0Y2hpbmcgcHJlZml4LlxuICogQSBwcmVmaXggbXVzdCBiZSBzcGVjaWZpZWQuIElmIHlvdSB3YW50IHRvIHJlbW92ZSBldmVyeXRoaW5nLCB0aGVuIGp1c3QgdXNlIGxvY2FsU3RvcmFnZS5jbGVhcigpLlxuICpcbiAqIEBwYXJhbSBwcmVmaXggS2V5cyB3aXRoIHRoaXMgcHJlZml4IHdpbGwgYmUgcmVtb3ZlZC5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGNsZWFyTG9jYWxTdG9yYWdlKHByZWZpeDogc3RyaW5nKSB7XG4gIGlmICghcHJlZml4KSB7XG4gICAgdGhyb3cgbmV3IExyQmFkQXJndW1lbnRFeGNlcHRpb24oJ1lvdSBtdXN0IHNwZWNpZnkgYSBub24gZW1wdHkgcHJlZml4LicpO1xuICB9XG5cbiAgLy8gUmVtb3ZlIGFsbCBwZXJzaXN0ZWQgc2Vzc2lvbiB2YXJpYWJsZXNcbiAgT2JqZWN0LmtleXMobG9jYWxTdG9yYWdlKS5mb3JFYWNoKChrZXkpID0+IHtcbiAgICBpZiAoa2V5LnN0YXJ0c1dpdGgocHJlZml4KSkge1xuICAgICAgbG9jYWxTdG9yYWdlLnJlbW92ZUl0ZW0oa2V5KTtcbiAgICB9XG4gIH0pO1xufVxuXG4vKipcbiAqIENsZWFyIGFsbCBpdGVtcyByZWxhdGVkIHRvIGNvZ25pdG8gaW4gbG9jYWxzdG9yYWdlLlxuICogVGhlIHJlbWVtYmVyIGRldmljZSBmdW5jdGlvbiBzb21ldGltZXMgaW50ZXJmZXJlcyB3aXRoIGNyZWF0aW5nIG5ldyB1c2Vyc1xuICogb24gVFAgYmFzZWQgcGFzc3dvcmQgcmVzZXQuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjbGVhckNvZ25pdG9Mb2NhbFN0b3JhZ2UoKSB7XG4gIGNsZWFyTG9jYWxTdG9yYWdlKENPR05JVE9fTE9DQUxTVE9SQUdFX1BSRUZJWCk7XG59XG4iXX0=
|
|
@@ -17,7 +17,6 @@ import { PasswordService } from '../password/password.service';
|
|
|
17
17
|
import { PersistService } from '../persist/persist.service';
|
|
18
18
|
import { ProfileService } from '../profile/profile.service';
|
|
19
19
|
import { PasswordChangeStatus } from '../profile/profile.types';
|
|
20
|
-
import { Slip39Service } from '../slip39/slip39.service';
|
|
21
20
|
import { TP_PASSWORD_RESET_CLIENT_NONCE_LENGTH, TP_PASSWORD_RESET_USERNAME_SUFFIX, } from '../tp-password-reset/tp-password-reset.constants';
|
|
22
21
|
import { TpPasswordResetAssemblyController } from '../tp-password-reset/tp-password-reset.controller';
|
|
23
22
|
import { CompleteTpPasswordResetRequestMutation, CreateTpAssemblyKeyChallengeMutation, PreCompleteTpPasswordResetRequestMutation, } from '../tp-password-reset/tp-password-reset.gql';
|
|
@@ -38,13 +37,12 @@ import * as i9 from "../api/lr-graphql/lr-graphql.service";
|
|
|
38
37
|
import * as i10 from "../api/query-processor/tp-password-reset-processor.service";
|
|
39
38
|
import * as i11 from "../persist/persist.service";
|
|
40
39
|
import * as i12 from "../encryption/encryption.service";
|
|
41
|
-
import * as i13 from "../
|
|
42
|
-
import * as i14 from "../tp-password-reset/tp-password-reset.controller";
|
|
40
|
+
import * as i13 from "../tp-password-reset/tp-password-reset.controller";
|
|
43
41
|
export const initialiseAuth = (authService) => {
|
|
44
42
|
return () => authService.initialise();
|
|
45
43
|
};
|
|
46
44
|
export class LifeReadyAuthService {
|
|
47
|
-
constructor(config, auth, keyFactory, keyService, profileService, keyGraphService, passwordService, idleService, lrGraphQL, tpPasswordResetProcessorService, persistService, encryptionService,
|
|
45
|
+
constructor(config, auth, keyFactory, keyService, profileService, keyGraphService, passwordService, idleService, lrGraphQL, tpPasswordResetProcessorService, persistService, encryptionService, assemblyController) {
|
|
48
46
|
this.config = config;
|
|
49
47
|
this.auth = auth;
|
|
50
48
|
this.keyFactory = keyFactory;
|
|
@@ -57,7 +55,6 @@ export class LifeReadyAuthService {
|
|
|
57
55
|
this.tpPasswordResetProcessorService = tpPasswordResetProcessorService;
|
|
58
56
|
this.persistService = persistService;
|
|
59
57
|
this.encryptionService = encryptionService;
|
|
60
|
-
this.slip39Service = slip39Service;
|
|
61
58
|
this.assemblyController = assemblyController;
|
|
62
59
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
63
60
|
this.hubSubject = new ReplaySubject(1);
|
|
@@ -477,7 +474,7 @@ export class LifeReadyAuthService {
|
|
|
477
474
|
});
|
|
478
475
|
}
|
|
479
476
|
}
|
|
480
|
-
LifeReadyAuthService.ɵprov = i0.ɵɵdefineInjectable({ factory: function LifeReadyAuthService_Factory() { return new LifeReadyAuthService(i0.ɵɵinject(i1.LR_CONFIG), i0.ɵɵinject(i2.AuthClass), i0.ɵɵinject(i3.KeyFactoryService), i0.ɵɵinject(i4.KeyService), i0.ɵɵinject(i5.ProfileService), i0.ɵɵinject(i6.KeyGraphService), i0.ɵɵinject(i7.PasswordService), i0.ɵɵinject(i8.IdleService), i0.ɵɵinject(i9.LrGraphQLService), i0.ɵɵinject(i10.TpPasswordResetProcessorService), i0.ɵɵinject(i11.PersistService), i0.ɵɵinject(i12.EncryptionService), i0.ɵɵinject(i13.
|
|
477
|
+
LifeReadyAuthService.ɵprov = i0.ɵɵdefineInjectable({ factory: function LifeReadyAuthService_Factory() { return new LifeReadyAuthService(i0.ɵɵinject(i1.LR_CONFIG), i0.ɵɵinject(i2.AuthClass), i0.ɵɵinject(i3.KeyFactoryService), i0.ɵɵinject(i4.KeyService), i0.ɵɵinject(i5.ProfileService), i0.ɵɵinject(i6.KeyGraphService), i0.ɵɵinject(i7.PasswordService), i0.ɵɵinject(i8.IdleService), i0.ɵɵinject(i9.LrGraphQLService), i0.ɵɵinject(i10.TpPasswordResetProcessorService), i0.ɵɵinject(i11.PersistService), i0.ɵɵinject(i12.EncryptionService), i0.ɵɵinject(i13.TpPasswordResetAssemblyController)); }, token: LifeReadyAuthService, providedIn: "root" });
|
|
481
478
|
LifeReadyAuthService.decorators = [
|
|
482
479
|
{ type: Injectable, args: [{
|
|
483
480
|
providedIn: 'root',
|
|
@@ -496,7 +493,6 @@ LifeReadyAuthService.ctorParameters = () => [
|
|
|
496
493
|
{ type: TpPasswordResetProcessorService },
|
|
497
494
|
{ type: PersistService },
|
|
498
495
|
{ type: EncryptionService },
|
|
499
|
-
{ type: Slip39Service },
|
|
500
496
|
{ type: TpPasswordResetAssemblyController }
|
|
501
497
|
];
|
|
502
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"life-ready-auth.service.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/auth/life-ready-auth.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, isDevMode } 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 { ReplaySubject } from 'rxjs';\nimport { LrGraphQLService, LrMutation } from '../api/lr-graphql';\nimport { TpPasswordResetProcessorService } from '../api/query-processor/tp-password-reset-processor.service';\nimport { TpClaimState, TpPasswordResetUserNode } 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 } from '../key/key.service';\nimport { PassIdpParams } from '../key/key.types';\nimport { LifeReadyConfig, LR_CONFIG } from '../life-ready.config';\nimport { PasswordService } from '../password/password.service';\nimport { PersistService } from '../persist/persist.service';\nimport { ProfileService } from '../profile/profile.service';\nimport { PasswordChangeStatus } from '../profile/profile.types';\nimport { Slip39Service } from '../slip39/slip39.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 { TpPasswordResetUserQuery } from '../tp-password-reset/tp-password-reset.private.gql';\nimport {\n  LrBadRequestException,\n  LrBadStateException,\n  LrConcurrentAccessException,\n  LrException,\n} from '../_common/exceptions';\nimport { SetSessionEncryptionKeyMutation } from './auth.gql';\nimport {\n  CognitoChallengeUser,\n  CurrentUser,\n  Features,\n  LoginResult,\n  RecoveryStatus,\n  TpPasswordResetUser,\n} from './auth.types';\n\nexport const initialiseAuth = (authService: LifeReadyAuthService) => {\n  return () => authService.initialise();\n};\n\nexport interface LoginOptions {\n  tpPasswordResetAutoComplete?: boolean;\n}\n\nexport type LogoutListener = () => void | Promise<void>;\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class LifeReadyAuthService {\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  private hubSubject: ReplaySubject<any> = new ReplaySubject<any>(1);\n  private currentUser: CurrentUser;\n  private currentResetUser: TpPasswordResetUser;\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\n  constructor(\n    @Inject(LR_CONFIG) private config: LifeReadyConfig,\n    private auth: AuthClass,\n    private keyFactory: KeyFactoryService,\n    private keyService: KeyService,\n    private profileService: ProfileService,\n    private keyGraphService: KeyGraphService,\n    private passwordService: PasswordService,\n    private idleService: IdleService,\n    private lrGraphQL: LrGraphQLService,\n    private tpPasswordResetProcessorService: TpPasswordResetProcessorService,\n    private persistService: PersistService,\n    private encryptionService: EncryptionService,\n    private slip39Service: Slip39Service,\n    private assemblyController: TpPasswordResetAssemblyController\n  ) {}\n\n  public async initialise() {\n    Hub.listen('auth', (data) => this.hubSubject.next(data.payload));\n  }\n\n  importPassword(plainPassword: string): Promise<CryptoKey> {\n    return this.keyFactory.importPassword(plainPassword);\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  private async loginIdpImpl(\n    emailOrPhone: string,\n    password: CryptoKey,\n    passIdpParams: PassIdpParams,\n    recoveryStatus: RecoveryStatus\n  ): Promise<CognitoChallengeUser> {\n    const passIdpResult = await this.keyFactory.derivePassIdp({\n      password,\n      ...passIdpParams,\n    });\n    // Use the derived password to signin with cognito\n    const user = await this.auth.signIn(\n      emailOrPhone,\n      this.passwordService.getPassIdpString(passIdpResult.jwk)\n    );\n\n    user.recoveryStatus = recoveryStatus;\n\n    return user;\n  }\n\n  private async loginIdp(\n    emailOrPhone: string,\n    password: CryptoKey\n  ): Promise<CognitoChallengeUser> {\n    // Download the salt needed to derive the PassIdp\n    const passIdpApiResult = await this.profileService.getPassIdpParams(\n      emailOrPhone\n    );\n\n    if (\n      passIdpApiResult.passwordChangeStatus === PasswordChangeStatus.InProgress\n    ) {\n      throw new LrConcurrentAccessException('A password change is in progress');\n    }\n\n    if (\n      passIdpApiResult.passwordChangeStatus === PasswordChangeStatus.Recovery\n    ) {\n      console.log('In recovery mode.');\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 = await this.loginIdpImpl(\n          emailOrPhone,\n          password,\n          passIdpApiResult.newPassIdpParams,\n          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 = await this.loginIdpImpl(\n          emailOrPhone,\n          password,\n          passIdpApiResult.currentPassIdpParams,\n          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 LrBadRequestException(\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 against 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 ret = await this.loginIdpImpl(\n          reset.resetUsername,\n          password,\n          reset.passIdpParams,\n          RecoveryStatus.NONE\n        );\n        ret.isTpPasswordResetUser = true;\n\n        return ret;\n      } catch (err) {\n        // continue, try again as regular user.\n      }\n    }\n\n    // Login as regular user\n    return await this.loginIdpImpl(\n      emailOrPhone,\n      password,\n      passIdpApiResult.currentPassIdpParams,\n      RecoveryStatus.NONE\n    );\n  }\n\n  protected async handleSessionEncryptionKey() {\n    if (this.config.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 Error(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.keyFactory.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  protected async handlePostAuth(cognitoUser: CognitoChallengeUser) {\n    await this.handlePasswordRecovery(cognitoUser);\n    await this.handleSessionEncryptionKey();\n  }\n\n  public async login(\n    emailOrPhone: string,\n    password: CryptoKey,\n    { tpPasswordResetAutoComplete = true }: LoginOptions = {}\n  ) {\n    let loginResult = await this.loginImpl(emailOrPhone, password);\n\n    if (\n      tpPasswordResetAutoComplete &&\n      loginResult.resetUser?.state === TpClaimState.APPROVED\n    ) {\n      await this.completeRequest(password);\n      loginResult = await this.loginImpl(emailOrPhone, password);\n    }\n\n    return loginResult;\n  }\n\n  public async loginImpl(\n    emailOrPhone: string,\n    password: CryptoKey\n  ): Promise<LoginResult> {\n    await this.logout();\n    const cognitoUser = await this.loginIdp(emailOrPhone, password);\n\n    // todo: Meet MFA challenges.\n    if (['SMS_MFA', 'SOFTWARE_TOKEN_MFA'].includes(cognitoUser.challengeName)) {\n      return { hasChallenge: true, challenge: cognitoUser };\n    }\n\n    await this.handlePostAuth(cognitoUser);\n\n    if (cognitoUser.isTpPasswordResetUser) {\n      // Assuming there is no MFA on the TP reset user.\n      const resetUser = await this.loadResetUser(password);\n      return { hasChallenge: false, resetUser };\n    } else {\n      const user = await this.loadUser(cognitoUser, password);\n      await this.idleService.start(); // Run idleService whenever user is logged in.\n      return { hasChallenge: false, user };\n    }\n  }\n\n  // TODO <AZ> We need to handle the isTpPasswordResetUser=True case here after MFA as well.\n  public async verifyLogin(\n    challenge: CognitoChallengeUser,\n    password: CryptoKey,\n    rememberMe: boolean,\n    code: string\n  ): Promise<CurrentUser> {\n    await this.auth.confirmSignIn(challenge, code, challenge.challengeName);\n\n    // TODO: this.auth.confirmSignIn() could return another challenge.\n\n    const cognitoUser: CognitoUser = await this.auth.currentAuthenticatedUser();\n\n    await this.handlePostAuth(challenge);\n\n    const user = await this.loadUser(cognitoUser, password);\n\n    if (rememberMe) {\n      cognitoUser.setDeviceStatusRemembered({\n        onSuccess: () => {\n          return;\n        },\n        onFailure: (e) => console.error(e),\n      });\n    }\n\n    return user;\n  }\n\n  async handlePasswordRecovery(user: CognitoChallengeUser) {\n    if (user.recoveryStatus !== RecoveryStatus.NONE) {\n      const jwtToken = user\n        .getSignInUserSession()\n        .getAccessToken()\n        .getJwtToken();\n      await this.passwordService.changePasswordComplete(\n        jwtToken,\n        user.recoveryStatus === RecoveryStatus.NEW_PASSWORD\n      );\n    }\n  }\n\n  async getUserOrResetUser(\n    reload = false\n  ): Promise<CurrentUser | TpPasswordResetUser> {\n    const cognitoUser = await this.auth.currentAuthenticatedUser();\n\n    if (cognitoUser.getUsername().endsWith(TP_PASSWORD_RESET_USERNAME_SUFFIX)) {\n      return this.getResetUser(reload);\n    } else {\n      return this.getUser(reload);\n    }\n  }\n\n  async getResetUser(reload = false): Promise<TpPasswordResetUser> {\n    if (!reload && this.currentResetUser) {\n      return this.currentResetUser;\n    }\n\n    this.currentResetUser = await this.loadResetUser();\n\n    await this.idleService.start(); // Run idleService whenever user is logged in.\n\n    return this.currentResetUser;\n  }\n\n  async getUser(reload = false): Promise<CurrentUser> {\n    if (!reload && this.currentUser) {\n      return this.currentUser;\n    }\n    this.currentUser = await this.loadUser(\n      await this.auth.currentAuthenticatedUser()\n    );\n    console.log('Starting idle service.');\n    await this.idleService.start(); // Run idleService whenever user is logged in.\n    return this.currentUser;\n  }\n\n  private mapTPVaultAccess(features?: Features): boolean {\n    const tpVaultFeature = features?.tpVault;\n    return (\n      tpVaultFeature?.length > 0 &&\n      tpVaultFeature.some((feature) => feature.toUpperCase() === 'ACCESS')\n    );\n  }\n\n  private async loadUser(\n    cognitoUser: CognitoUser,\n    password?: CryptoKey\n  ): Promise<CurrentUser> {\n    const { currentUser, contactCard, userPlans } =\n      await this.profileService.getCurrentUser();\n\n    if (currentUser.sessionEncryptionKey) {\n      this.persistService.setServerSessionEncryptionKey(\n        await JWK.asKey(currentUser.sessionEncryptionKey)\n      );\n    }\n\n    const userAttributes = await this.auth.userAttributes(cognitoUser);\n\n    if (password) {\n      const passKey = (\n        await this.keyFactory.derivePassKey({\n          password,\n          ...currentUser.currentUserKey.passKey.passKeyParams,\n        })\n      ).jwk;\n\n      await this.idleService.persistMasterKey(\n        await this.keyGraphService.unwrapWithPassKey(\n          currentUser.currentUserKey.passKey.id,\n          passKey,\n          currentUser.currentUserKey.masterKey.id\n        )\n      );\n    }\n    await this.keyGraphService.populateKeys(currentUser.currentUserKey);\n\n    return {\n      id: currentUser.id,\n      sub: this.getUserAttribute('sub', userAttributes),\n      username: currentUser.username,\n      currentUserKey: currentUser.currentUserKey,\n      getAccessJwtToken: () =>\n        cognitoUser.getSignInUserSession().getAccessToken().getJwtToken(),\n      email: this.getUserAttribute('email', userAttributes),\n      emailVerified:\n        this.getUserAttribute('email_verified', userAttributes) === 'true',\n      phone: this.getUserAttribute('phone_number', userAttributes),\n      phoneVerified:\n        this.getUserAttribute('phone_number_verified', userAttributes) ===\n        'true',\n      contactCard: {\n        ...(await this.profileService.decryptContactCard(contactCard)),\n      },\n      userDelete: currentUser.userDelete,\n      userPlans,\n      hasTPVaultAccess: this.mapTPVaultAccess(currentUser.features),\n      features: currentUser.features,\n      sessionEncryptionKey: currentUser.sessionEncryptionKey,\n    };\n  }\n\n  public watchAuth() {\n    return this.hubSubject;\n  }\n\n  public async logout(): Promise<void> {\n    // Notify all listeners to clean up.\n    await Promise.all([...this.logoutListeners].map((callback) => callback()));\n\n    this.currentUser = null;\n    this.keyService.purgeKeys();\n    this.keyGraphService.purgeKeys();\n\n    await Promise.all([this.auth.signOut(), this.profileService.signOut()]);\n  }\n\n  private getUserAttribute(\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  public async loadResetUser(\n    password?: CryptoKey\n  ): Promise<TpPasswordResetUser> {\n    const { tpPasswordResetUser: resetUser } = await this.lrGraphQL.query({\n      query: TpPasswordResetUserQuery,\n    });\n\n    if (resetUser.sessionEncryptionKey) {\n      this.persistService.setServerSessionEncryptionKey(\n        await JWK.asKey(resetUser.sessionEncryptionKey)\n      );\n    }\n\n    // Update the keys\n    if (password) {\n      const passKey = (\n        await this.keyFactory.derivePassKey({\n          password,\n          ...resetUser.passKey.passKeyParams,\n        })\n      ).jwk;\n\n      await this.idleService.persistMasterKey(\n        await this.keyGraphService.unwrapWithPassKey(\n          resetUser.passKey.id,\n          passKey,\n          resetUser.masterKey.id\n        )\n      );\n    }\n\n    this.keyService.populateKeys({\n      passKey: {\n        id: resetUser.passKey.id,\n      },\n      masterKey: {\n        id: resetUser.masterKey.id,\n      },\n    });\n\n    const userAttributes = await this.auth.userAttributes(\n      await this.auth.currentAuthenticatedUser()\n    );\n    const sub = this.getUserAttribute('sub', userAttributes);\n\n    return {\n      ...(await this.tpPasswordResetProcessorService.processTpPasswordResetUserNode(\n        resetUser\n      )),\n      sub,\n    };\n  }\n\n  public async refreshAccessToken() {\n    const cognitoUser: CognitoUser = await this.auth.currentAuthenticatedUser();\n    const refreshToken = cognitoUser.getSignInUserSession().getRefreshToken();\n\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  async completeRequest(newPassword: CryptoKey): Promise<void> {\n    const resetUser = await this.getResetUser(true);\n\n    if (resetUser.state !== TpClaimState.APPROVED) {\n      throw new LrBadStateException(\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.keyFactory.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.keyFactory.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    // The 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.auth.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.auth.signIn(resetUser.username, tempIdpPassword, {\n      noProxy: 'true',\n    });\n\n    if (user.challengeName !== 'NEW_PASSWORD_REQUIRED') {\n      throw new LrException({\n        message:\n          'Internal error. 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.auth.completeNewPassword(user, newIdpPassword, {});\n\n    return retPromise;\n  }\n\n  private async recoverAssemblyKey(\n    resetUser: TpPasswordResetUserNode\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"]}
|
|
498
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"life-ready-auth.service.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/auth/life-ready-auth.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, isDevMode } 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 { ReplaySubject } from 'rxjs';\nimport { LrGraphQLService, LrMutation } from '../api/lr-graphql';\nimport { TpPasswordResetProcessorService } from '../api/query-processor/tp-password-reset-processor.service';\nimport { TpClaimState, TpPasswordResetUserNode } 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 } from '../key/key.service';\nimport { PassIdpParams } from '../key/key.types';\nimport { LifeReadyConfig, LR_CONFIG } from '../life-ready.config';\nimport { PasswordService } from '../password/password.service';\nimport { PersistService } from '../persist/persist.service';\nimport { ProfileService } from '../profile/profile.service';\nimport { PasswordChangeStatus } from '../profile/profile.types';\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 { TpPasswordResetUserQuery } from '../tp-password-reset/tp-password-reset.private.gql';\nimport {\n  LrBadRequestException,\n  LrBadStateException,\n  LrConcurrentAccessException,\n  LrException,\n} from '../_common/exceptions';\nimport { SetSessionEncryptionKeyMutation } from './auth.gql';\nimport {\n  CognitoChallengeUser,\n  CurrentUser,\n  Features,\n  LoginResult,\n  RecoveryStatus,\n  TpPasswordResetUser,\n} from './auth.types';\n\nexport const initialiseAuth = (authService: LifeReadyAuthService) => {\n  return () => authService.initialise();\n};\n\nexport interface LoginOptions {\n  tpPasswordResetAutoComplete?: boolean;\n}\n\nexport type LogoutListener = () => void | Promise<void>;\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class LifeReadyAuthService {\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  private hubSubject: ReplaySubject<any> = new ReplaySubject<any>(1);\n  private currentUser: CurrentUser;\n  private currentResetUser: TpPasswordResetUser;\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\n  constructor(\n    @Inject(LR_CONFIG) private config: LifeReadyConfig,\n    private auth: AuthClass,\n    private keyFactory: KeyFactoryService,\n    private keyService: KeyService,\n    private profileService: ProfileService,\n    private keyGraphService: KeyGraphService,\n    private passwordService: PasswordService,\n    private idleService: IdleService,\n    private lrGraphQL: LrGraphQLService,\n    private tpPasswordResetProcessorService: TpPasswordResetProcessorService,\n    private persistService: PersistService,\n    private encryptionService: EncryptionService,\n    private assemblyController: TpPasswordResetAssemblyController\n  ) {}\n\n  public async initialise() {\n    Hub.listen('auth', (data) => this.hubSubject.next(data.payload));\n  }\n\n  importPassword(plainPassword: string): Promise<CryptoKey> {\n    return this.keyFactory.importPassword(plainPassword);\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  private async loginIdpImpl(\n    emailOrPhone: string,\n    password: CryptoKey,\n    passIdpParams: PassIdpParams,\n    recoveryStatus: RecoveryStatus\n  ): Promise<CognitoChallengeUser> {\n    const passIdpResult = await this.keyFactory.derivePassIdp({\n      password,\n      ...passIdpParams,\n    });\n    // Use the derived password to signin with cognito\n    const user = await this.auth.signIn(\n      emailOrPhone,\n      this.passwordService.getPassIdpString(passIdpResult.jwk)\n    );\n\n    user.recoveryStatus = recoveryStatus;\n\n    return user;\n  }\n\n  private async loginIdp(\n    emailOrPhone: string,\n    password: CryptoKey\n  ): Promise<CognitoChallengeUser> {\n    // Download the salt needed to derive the PassIdp\n    const passIdpApiResult = await this.profileService.getPassIdpParams(\n      emailOrPhone\n    );\n\n    if (\n      passIdpApiResult.passwordChangeStatus === PasswordChangeStatus.InProgress\n    ) {\n      throw new LrConcurrentAccessException('A password change is in progress');\n    }\n\n    if (\n      passIdpApiResult.passwordChangeStatus === PasswordChangeStatus.Recovery\n    ) {\n      console.log('In recovery mode.');\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 = await this.loginIdpImpl(\n          emailOrPhone,\n          password,\n          passIdpApiResult.newPassIdpParams,\n          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 = await this.loginIdpImpl(\n          emailOrPhone,\n          password,\n          passIdpApiResult.currentPassIdpParams,\n          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 LrBadRequestException(\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 against 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 ret = await this.loginIdpImpl(\n          reset.resetUsername,\n          password,\n          reset.passIdpParams,\n          RecoveryStatus.NONE\n        );\n        ret.isTpPasswordResetUser = true;\n\n        return ret;\n      } catch (err) {\n        // continue, try again as regular user.\n      }\n    }\n\n    // Login as regular user\n    return await this.loginIdpImpl(\n      emailOrPhone,\n      password,\n      passIdpApiResult.currentPassIdpParams,\n      RecoveryStatus.NONE\n    );\n  }\n\n  protected async handleSessionEncryptionKey() {\n    if (this.config.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 Error(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.keyFactory.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  protected async handlePostAuth(cognitoUser: CognitoChallengeUser) {\n    await this.handlePasswordRecovery(cognitoUser);\n    await this.handleSessionEncryptionKey();\n  }\n\n  public async login(\n    emailOrPhone: string,\n    password: CryptoKey,\n    { tpPasswordResetAutoComplete = true }: LoginOptions = {}\n  ) {\n    let loginResult = await this.loginImpl(emailOrPhone, password);\n\n    if (\n      tpPasswordResetAutoComplete &&\n      loginResult.resetUser?.state === TpClaimState.APPROVED\n    ) {\n      await this.completeRequest(password);\n      loginResult = await this.loginImpl(emailOrPhone, password);\n    }\n\n    return loginResult;\n  }\n\n  public async loginImpl(\n    emailOrPhone: string,\n    password: CryptoKey\n  ): Promise<LoginResult> {\n    await this.logout();\n    const cognitoUser = await this.loginIdp(emailOrPhone, password);\n\n    // todo: Meet MFA challenges.\n    if (['SMS_MFA', 'SOFTWARE_TOKEN_MFA'].includes(cognitoUser.challengeName)) {\n      return { hasChallenge: true, challenge: cognitoUser };\n    }\n\n    await this.handlePostAuth(cognitoUser);\n\n    if (cognitoUser.isTpPasswordResetUser) {\n      // Assuming there is no MFA on the TP reset user.\n      const resetUser = await this.loadResetUser(password);\n      return { hasChallenge: false, resetUser };\n    } else {\n      const user = await this.loadUser(cognitoUser, password);\n      await this.idleService.start(); // Run idleService whenever user is logged in.\n      return { hasChallenge: false, user };\n    }\n  }\n\n  // TODO <AZ> We need to handle the isTpPasswordResetUser=True case here after MFA as well.\n  public async verifyLogin(\n    challenge: CognitoChallengeUser,\n    password: CryptoKey,\n    rememberMe: boolean,\n    code: string\n  ): Promise<CurrentUser> {\n    await this.auth.confirmSignIn(challenge, code, challenge.challengeName);\n\n    // TODO: this.auth.confirmSignIn() could return another challenge.\n\n    const cognitoUser: CognitoUser = await this.auth.currentAuthenticatedUser();\n\n    await this.handlePostAuth(challenge);\n\n    const user = await this.loadUser(cognitoUser, password);\n\n    if (rememberMe) {\n      cognitoUser.setDeviceStatusRemembered({\n        onSuccess: () => {\n          return;\n        },\n        onFailure: (e) => console.error(e),\n      });\n    }\n\n    return user;\n  }\n\n  async handlePasswordRecovery(user: CognitoChallengeUser) {\n    if (user.recoveryStatus !== RecoveryStatus.NONE) {\n      const jwtToken = user\n        .getSignInUserSession()\n        .getAccessToken()\n        .getJwtToken();\n      await this.passwordService.changePasswordComplete(\n        jwtToken,\n        user.recoveryStatus === RecoveryStatus.NEW_PASSWORD\n      );\n    }\n  }\n\n  async getUserOrResetUser(\n    reload = false\n  ): Promise<CurrentUser | TpPasswordResetUser> {\n    const cognitoUser = await this.auth.currentAuthenticatedUser();\n\n    if (cognitoUser.getUsername().endsWith(TP_PASSWORD_RESET_USERNAME_SUFFIX)) {\n      return this.getResetUser(reload);\n    } else {\n      return this.getUser(reload);\n    }\n  }\n\n  async getResetUser(reload = false): Promise<TpPasswordResetUser> {\n    if (!reload && this.currentResetUser) {\n      return this.currentResetUser;\n    }\n\n    this.currentResetUser = await this.loadResetUser();\n\n    await this.idleService.start(); // Run idleService whenever user is logged in.\n\n    return this.currentResetUser;\n  }\n\n  async getUser(reload = false): Promise<CurrentUser> {\n    if (!reload && this.currentUser) {\n      return this.currentUser;\n    }\n    this.currentUser = await this.loadUser(\n      await this.auth.currentAuthenticatedUser()\n    );\n    console.log('Starting idle service.');\n    await this.idleService.start(); // Run idleService whenever user is logged in.\n    return this.currentUser;\n  }\n\n  private mapTPVaultAccess(features?: Features): boolean {\n    const tpVaultFeature = features?.tpVault;\n    return (\n      tpVaultFeature?.length > 0 &&\n      tpVaultFeature.some((feature) => feature.toUpperCase() === 'ACCESS')\n    );\n  }\n\n  private async loadUser(\n    cognitoUser: CognitoUser,\n    password?: CryptoKey\n  ): Promise<CurrentUser> {\n    const { currentUser, contactCard, userPlans } =\n      await this.profileService.getCurrentUser();\n\n    if (currentUser.sessionEncryptionKey) {\n      this.persistService.setServerSessionEncryptionKey(\n        await JWK.asKey(currentUser.sessionEncryptionKey)\n      );\n    }\n\n    const userAttributes = await this.auth.userAttributes(cognitoUser);\n\n    if (password) {\n      const passKey = (\n        await this.keyFactory.derivePassKey({\n          password,\n          ...currentUser.currentUserKey.passKey.passKeyParams,\n        })\n      ).jwk;\n\n      await this.idleService.persistMasterKey(\n        await this.keyGraphService.unwrapWithPassKey(\n          currentUser.currentUserKey.passKey.id,\n          passKey,\n          currentUser.currentUserKey.masterKey.id\n        )\n      );\n    }\n    await this.keyGraphService.populateKeys(currentUser.currentUserKey);\n\n    return {\n      id: currentUser.id,\n      sub: this.getUserAttribute('sub', userAttributes),\n      username: currentUser.username,\n      currentUserKey: currentUser.currentUserKey,\n      getAccessJwtToken: () =>\n        cognitoUser.getSignInUserSession().getAccessToken().getJwtToken(),\n      email: this.getUserAttribute('email', userAttributes),\n      emailVerified:\n        this.getUserAttribute('email_verified', userAttributes) === 'true',\n      phone: this.getUserAttribute('phone_number', userAttributes),\n      phoneVerified:\n        this.getUserAttribute('phone_number_verified', userAttributes) ===\n        'true',\n      contactCard: {\n        ...(await this.profileService.decryptContactCard(contactCard)),\n      },\n      userDelete: currentUser.userDelete,\n      userPlans,\n      hasTPVaultAccess: this.mapTPVaultAccess(currentUser.features),\n      features: currentUser.features,\n      sessionEncryptionKey: currentUser.sessionEncryptionKey,\n    };\n  }\n\n  public watchAuth() {\n    return this.hubSubject;\n  }\n\n  public async logout(): Promise<void> {\n    // Notify all listeners to clean up.\n    await Promise.all([...this.logoutListeners].map((callback) => callback()));\n\n    this.currentUser = null;\n    this.keyService.purgeKeys();\n    this.keyGraphService.purgeKeys();\n\n    await Promise.all([this.auth.signOut(), this.profileService.signOut()]);\n  }\n\n  private getUserAttribute(\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  public async loadResetUser(\n    password?: CryptoKey\n  ): Promise<TpPasswordResetUser> {\n    const { tpPasswordResetUser: resetUser } = await this.lrGraphQL.query({\n      query: TpPasswordResetUserQuery,\n    });\n\n    if (resetUser.sessionEncryptionKey) {\n      this.persistService.setServerSessionEncryptionKey(\n        await JWK.asKey(resetUser.sessionEncryptionKey)\n      );\n    }\n\n    // Update the keys\n    if (password) {\n      const passKey = (\n        await this.keyFactory.derivePassKey({\n          password,\n          ...resetUser.passKey.passKeyParams,\n        })\n      ).jwk;\n\n      await this.idleService.persistMasterKey(\n        await this.keyGraphService.unwrapWithPassKey(\n          resetUser.passKey.id,\n          passKey,\n          resetUser.masterKey.id\n        )\n      );\n    }\n\n    this.keyService.populateKeys({\n      passKey: {\n        id: resetUser.passKey.id,\n      },\n      masterKey: {\n        id: resetUser.masterKey.id,\n      },\n    });\n\n    const userAttributes = await this.auth.userAttributes(\n      await this.auth.currentAuthenticatedUser()\n    );\n    const sub = this.getUserAttribute('sub', userAttributes);\n\n    return {\n      ...(await this.tpPasswordResetProcessorService.processTpPasswordResetUserNode(\n        resetUser\n      )),\n      sub,\n    };\n  }\n\n  public async refreshAccessToken() {\n    const cognitoUser: CognitoUser = await this.auth.currentAuthenticatedUser();\n    const refreshToken = cognitoUser.getSignInUserSession().getRefreshToken();\n\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  async completeRequest(newPassword: CryptoKey): Promise<void> {\n    const resetUser = await this.getResetUser(true);\n\n    if (resetUser.state !== TpClaimState.APPROVED) {\n      throw new LrBadStateException(\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.keyFactory.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.keyFactory.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    // The 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.auth.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.auth.signIn(resetUser.username, tempIdpPassword, {\n      noProxy: 'true',\n    });\n\n    if (user.challengeName !== 'NEW_PASSWORD_REQUIRED') {\n      throw new LrException({\n        message:\n          'Internal error. 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.auth.completeNewPassword(user, newIdpPassword, {});\n\n    return retPromise;\n  }\n\n  private async recoverAssemblyKey(\n    resetUser: TpPasswordResetUserNode\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"]}
|
|
@@ -8,6 +8,7 @@ import { KeyFactoryService } from '../key/key-factory.service';
|
|
|
8
8
|
import { LR_CONFIG } from '../life-ready.config';
|
|
9
9
|
import { PasswordService } from '../password/password.service';
|
|
10
10
|
import { RunOutsideAngular } from '../_common/run-outside-angular';
|
|
11
|
+
import { clearCognitoLocalStorage } from '../_common/storage';
|
|
11
12
|
import * as i0 from "@angular/core";
|
|
12
13
|
import * as i1 from "../life-ready.config";
|
|
13
14
|
import * as i2 from "../key/key-factory.service";
|
|
@@ -51,6 +52,9 @@ let TpPasswordResetUserService = class TpPasswordResetUserService extends LrServ
|
|
|
51
52
|
}
|
|
52
53
|
requestReset(password, claimId, claimToken) {
|
|
53
54
|
return __awaiter(this, void 0, void 0, function* () {
|
|
55
|
+
// Clearing all localstorage data because cognito has the "remember device" functionality which sometimes
|
|
56
|
+
// does not work properly. Clearing localstorage seems to solve this issue.
|
|
57
|
+
clearCognitoLocalStorage();
|
|
54
58
|
// Generate the key materials
|
|
55
59
|
const passKeyBundle = yield this.passwordService.createPassKeyBundle(password);
|
|
56
60
|
const masterKey = yield this.keyFactory.createKey();
|
|
@@ -114,4 +118,4 @@ TpPasswordResetUserService = __decorate([
|
|
|
114
118
|
})
|
|
115
119
|
], TpPasswordResetUserService);
|
|
116
120
|
export { TpPasswordResetUserService };
|
|
117
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tp-password-reset-user.service.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/tp-password-reset/tp-password-reset-user.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\nimport { Inject, Injectable, Injector, NgZone } from '@angular/core';\nimport { AuthClass } from '@aws-amplify/auth/lib-esm/Auth';\nimport { ISignUpResult } from 'amazon-cognito-identity-js';\nimport { LrService } from '../api/lr-graphql';\nimport { EncryptionService } from '../encryption/encryption.service';\nimport { KeyFactoryService } from '../key/key-factory.service';\nimport { LifeReadyConfig, LR_CONFIG } from '../life-ready.config';\nimport { PasswordService } from '../password/password.service';\nimport { RunOutsideAngular } from '../_common/run-outside-angular';\nimport { RequestResetResult } from './tp-password-reset.types';\n\n@RunOutsideAngular({\n  ngZoneName: 'ngZone',\n})\n@Injectable({\n  providedIn: 'root',\n})\nexport class TpPasswordResetUserService extends LrService {\n  constructor(\n    private ngZone: NgZone,\n    private injector: Injector,\n    @Inject(LR_CONFIG) private config: LifeReadyConfig,\n    private keyFactory: KeyFactoryService,\n    private encryptionService: EncryptionService,\n    private passwordService: PasswordService,\n    private http: HttpClient,\n    private auth: AuthClass\n  ) {\n    super(injector);\n  }\n\n  async verifyEmailContact(email): Promise<{ claimId: string }> {\n    const params = {\n      email,\n    };\n    return (\n      this.http\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\n        .post<any>(\n          `${this.config.authUrl}tp/password-reset/verify-contact/`,\n          params\n        )\n        .toPromise()\n    );\n  }\n\n  async verifyContactRespond(\n    claimId: string,\n    claimCode: string\n  ): Promise<string> {\n    const { token } = await this.http\n      .post<{ token }>(`${this.config.authUrl}cove/respond/`, {\n        claim_id: claimId,\n        v_code: claimCode,\n      })\n      .toPromise();\n    return token;\n  }\n\n  async requestReset(\n    password: CryptoKey,\n    claimId: string,\n    claimToken: string\n  ): Promise<{\n    requestResetResult: RequestResetResult;\n    signUpResult: ISignUpResult;\n  }> {\n    // Generate the key materials\n    const passKeyBundle = await this.passwordService.createPassKeyBundle(\n      password\n    );\n\n    const masterKey = await this.keyFactory.createKey();\n    const wrappedMasterKey = await this.encryptionService.encrypt(\n      passKeyBundle.passKey,\n      masterKey.toJSON(true)\n    );\n\n    // Ephemeral PKC key\n    const prk = await this.keyFactory.createPkcKey();\n    const masterKeyWrappedPrk = await this.encryptionService.encrypt(\n      masterKey,\n      prk.toJSON(true)\n    );\n\n    // API call to setup reset request\n    const requestResetResult = await this.http\n      .post<RequestResetResult>(\n        `${this.config.authUrl}tp/password-reset/request/`,\n        {\n          claimId,\n          claimToken,\n          pass_key_params: passKeyBundle.passKeyParams,\n          pass_idp_params: passKeyBundle.passIdpParams,\n          pass_idp_verifier_pbk: passKeyBundle.passIdpVerifier.toJSON(), // public key\n          wrapped_pass_idp_verifier_prk:\n            passKeyBundle.wrappedPassIdpVerifierPrk,\n          wrapped_master_key: wrappedMasterKey,\n          pbk: prk.toJSON(), // ephemeral public key\n          master_key_wrapped_prk: masterKeyWrappedPrk,\n        }\n      )\n      .toPromise();\n\n    console.log('Using new password');\n\n    // API call to create user on cognito\n    const signUpResult = await this.auth.signUp({\n      username: requestResetResult.reset_username,\n      password: this.passwordService.getPassIdpString(passKeyBundle.passIdp),\n      clientMetadata: {\n        tp_password_reset_request: JSON.stringify({\n          id: requestResetResult.id,\n          associate_reset_user_token:\n            requestResetResult.associate_reset_user_token,\n        }),\n      },\n    });\n\n    console.log('requestRest done');\n\n    return {\n      requestResetResult,\n      signUpResult,\n    };\n  }\n}\n"]}
|
|
121
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tp-password-reset-user.service.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/tp-password-reset/tp-password-reset-user.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\nimport { Inject, Injectable, Injector, NgZone } from '@angular/core';\nimport { AuthClass } from '@aws-amplify/auth/lib-esm/Auth';\nimport { ISignUpResult } from 'amazon-cognito-identity-js';\nimport { LrService } from '../api/lr-graphql';\nimport { EncryptionService } from '../encryption/encryption.service';\nimport { KeyFactoryService } from '../key/key-factory.service';\nimport { LifeReadyConfig, LR_CONFIG } from '../life-ready.config';\nimport { PasswordService } from '../password/password.service';\nimport { RunOutsideAngular } from '../_common/run-outside-angular';\nimport { clearCognitoLocalStorage } from '../_common/storage';\nimport { RequestResetResult } from './tp-password-reset.types';\n\n@RunOutsideAngular({\n  ngZoneName: 'ngZone',\n})\n@Injectable({\n  providedIn: 'root',\n})\nexport class TpPasswordResetUserService extends LrService {\n  constructor(\n    private ngZone: NgZone,\n    private injector: Injector,\n    @Inject(LR_CONFIG) private config: LifeReadyConfig,\n    private keyFactory: KeyFactoryService,\n    private encryptionService: EncryptionService,\n    private passwordService: PasswordService,\n    private http: HttpClient,\n    private auth: AuthClass\n  ) {\n    super(injector);\n  }\n\n  async verifyEmailContact(email): Promise<{ claimId: string }> {\n    const params = {\n      email,\n    };\n    return (\n      this.http\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\n        .post<any>(\n          `${this.config.authUrl}tp/password-reset/verify-contact/`,\n          params\n        )\n        .toPromise()\n    );\n  }\n\n  async verifyContactRespond(\n    claimId: string,\n    claimCode: string\n  ): Promise<string> {\n    const { token } = await this.http\n      .post<{ token }>(`${this.config.authUrl}cove/respond/`, {\n        claim_id: claimId,\n        v_code: claimCode,\n      })\n      .toPromise();\n    return token;\n  }\n\n  async requestReset(\n    password: CryptoKey,\n    claimId: string,\n    claimToken: string\n  ): Promise<{\n    requestResetResult: RequestResetResult;\n    signUpResult: ISignUpResult;\n  }> {\n    // Clearing all localstorage data because cognito has the \"remember device\" functionality which sometimes\n    // does not work properly. Clearing localstorage seems to solve this issue.\n    clearCognitoLocalStorage();\n\n    // Generate the key materials\n    const passKeyBundle = await this.passwordService.createPassKeyBundle(\n      password\n    );\n\n    const masterKey = await this.keyFactory.createKey();\n    const wrappedMasterKey = await this.encryptionService.encrypt(\n      passKeyBundle.passKey,\n      masterKey.toJSON(true)\n    );\n\n    // Ephemeral PKC key\n    const prk = await this.keyFactory.createPkcKey();\n    const masterKeyWrappedPrk = await this.encryptionService.encrypt(\n      masterKey,\n      prk.toJSON(true)\n    );\n\n    // API call to setup reset request\n    const requestResetResult = await this.http\n      .post<RequestResetResult>(\n        `${this.config.authUrl}tp/password-reset/request/`,\n        {\n          claimId,\n          claimToken,\n          pass_key_params: passKeyBundle.passKeyParams,\n          pass_idp_params: passKeyBundle.passIdpParams,\n          pass_idp_verifier_pbk: passKeyBundle.passIdpVerifier.toJSON(), // public key\n          wrapped_pass_idp_verifier_prk:\n            passKeyBundle.wrappedPassIdpVerifierPrk,\n          wrapped_master_key: wrappedMasterKey,\n          pbk: prk.toJSON(), // ephemeral public key\n          master_key_wrapped_prk: masterKeyWrappedPrk,\n        }\n      )\n      .toPromise();\n\n    console.log('Using new password');\n\n    // API call to create user on cognito\n    const signUpResult = await this.auth.signUp({\n      username: requestResetResult.reset_username,\n      password: this.passwordService.getPassIdpString(passKeyBundle.passIdp),\n      clientMetadata: {\n        tp_password_reset_request: JSON.stringify({\n          id: requestResetResult.id,\n          associate_reset_user_token:\n            requestResetResult.associate_reset_user_token,\n        }),\n      },\n    });\n\n    console.log('requestRest done');\n\n    return {\n      requestResetResult,\n      signUpResult,\n    };\n  }\n}\n"]}
|
|
@@ -3,18 +3,17 @@
|
|
|
3
3
|
*/
|
|
4
4
|
export * from './public-api';
|
|
5
5
|
export { RunOutsideAngular as ɵh } from './lib/_common/run-outside-angular';
|
|
6
|
-
export { LrGraphQLService as ɵf, LrService as
|
|
6
|
+
export { LrGraphQLService as ɵf, LrService as ɵk } from './lib/api/lr-graphql';
|
|
7
7
|
export { TpPasswordResetProcessorService as ɵg } from './lib/api/query-processor/tp-password-reset-processor.service';
|
|
8
8
|
export { EncryptionService as ɵb } from './lib/encryption/encryption.service';
|
|
9
9
|
export { KeyFactoryService as ɵd } from './lib/key/key-factory.service';
|
|
10
10
|
export { KeyGraphService as ɵa } from './lib/key/key-graph.service';
|
|
11
11
|
export { KeyMetaService as ɵe } from './lib/key/key-meta.service';
|
|
12
12
|
export { KeyService as ɵc } from './lib/key/key.service';
|
|
13
|
-
export { ScenarioAssemblyController as
|
|
14
|
-
export { SharedContactCardService as
|
|
15
|
-
export {
|
|
16
|
-
export {
|
|
17
|
-
export {
|
|
18
|
-
export {
|
|
19
|
-
|
|
20
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlmZXJlYWR5LWNvcmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3NyYy9saWZlcmVhZHktY29yZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDO0FBRTdCLE9BQU8sRUFBQyxpQkFBaUIsSUFBSSxFQUFFLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQztBQUMxRSxPQUFPLEVBQUMsZ0JBQWdCLElBQUksRUFBRSxFQUFDLFNBQVMsSUFBSSxFQUFFLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQztBQUM1RSxPQUFPLEVBQUMsK0JBQStCLElBQUksRUFBRSxFQUFDLE1BQU0sK0RBQStELENBQUM7QUFDcEgsT0FBTyxFQUFDLGlCQUFpQixJQUFJLEVBQUUsRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBQzVFLE9BQU8sRUFBQyxpQkFBaUIsSUFBSSxFQUFFLEVBQUMsTUFBTSwrQkFBK0IsQ0FBQztBQUN0RSxPQUFPLEVBQUMsZUFBZSxJQUFJLEVBQUUsRUFBQyxNQUFNLDZCQUE2QixDQUFDO0FBQ2xFLE9BQU8sRUFBQyxjQUFjLElBQUksRUFBRSxFQUFDLE1BQU0sNEJBQTRCLENBQUM7QUFDaEUsT0FBTyxFQUFDLFVBQVUsSUFBSSxFQUFFLEVBQUMsTUFBTSx1QkFBdUIsQ0FBQztBQUN2RCxPQUFPLEVBQUMsMEJBQTBCLElBQUksRUFBRSxFQUFDLE1BQU0sb0NBQW9DLENBQUM7QUFDcEYsT0FBTyxFQUFDLHdCQUF3QixJQUFJLEVBQUUsRUFBQyxNQUFNLHVEQUF1RCxDQUFDO0FBQ3JHLE9BQU8sRUFBQyxhQUFhLElBQUksRUFBRSxFQUFDLE1BQU0sNkJBQTZCLENBQUM7QUFDaEUsT0FBTyxFQUFDLG9CQUFvQixJQUFJLEVBQUUsRUFBQyxNQUFNLCtCQUErQixDQUFDO0FBQ3pFLE9BQU8sRUFBQyxpQ0FBaUMsSUFBSSxFQUFFLEVBQUMsTUFBTSxzREFBc0QsQ0FBQztBQUM3RyxPQUFPLEVBQUMsNkJBQTZCLElBQUksRUFBRSxFQUFDLE1BQU0sMkRBQTJELENBQUM7QUFDOUcsT0FBTyxFQUFDLG1CQUFtQixJQUFJLEVBQUUsRUFBQyxNQUFNLDJDQUEyQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpYy1hcGknO1xuXG5leHBvcnQge1J1bk91dHNpZGVBbmd1bGFyIGFzIMm1aH0gZnJvbSAnLi9saWIvX2NvbW1vbi9ydW4tb3V0c2lkZS1hbmd1bGFyJztcbmV4cG9ydCB7THJHcmFwaFFMU2VydmljZSBhcyDJtWYsTHJTZXJ2aWNlIGFzIMm1bH0gZnJvbSAnLi9saWIvYXBpL2xyLWdyYXBocWwnO1xuZXhwb3J0IHtUcFBhc3N3b3JkUmVzZXRQcm9jZXNzb3JTZXJ2aWNlIGFzIMm1Z30gZnJvbSAnLi9saWIvYXBpL3F1ZXJ5LXByb2Nlc3Nvci90cC1wYXNzd29yZC1yZXNldC1wcm9jZXNzb3Iuc2VydmljZSc7XG5leHBvcnQge0VuY3J5cHRpb25TZXJ2aWNlIGFzIMm1Yn0gZnJvbSAnLi9saWIvZW5jcnlwdGlvbi9lbmNyeXB0aW9uLnNlcnZpY2UnO1xuZXhwb3J0IHtLZXlGYWN0b3J5U2VydmljZSBhcyDJtWR9IGZyb20gJy4vbGliL2tleS9rZXktZmFjdG9yeS5zZXJ2aWNlJztcbmV4cG9ydCB7S2V5R3JhcGhTZXJ2aWNlIGFzIMm1YX0gZnJvbSAnLi9saWIva2V5L2tleS1ncmFwaC5zZXJ2aWNlJztcbmV4cG9ydCB7S2V5TWV0YVNlcnZpY2UgYXMgybVlfSBmcm9tICcuL2xpYi9rZXkva2V5LW1ldGEuc2VydmljZSc7XG5leHBvcnQge0tleVNlcnZpY2UgYXMgybVjfSBmcm9tICcuL2xpYi9rZXkva2V5LnNlcnZpY2UnO1xuZXhwb3J0IHtTY2VuYXJpb0Fzc2VtYmx5Q29udHJvbGxlciBhcyDJtW99IGZyb20gJy4vbGliL3NjZW5hcmlvL3NjZW5hcmlvLmNvbnRyb2xsZXInO1xuZXhwb3J0IHtTaGFyZWRDb250YWN0Q2FyZFNlcnZpY2UgYXMgybVtfSBmcm9tICcuL2xpYi9zaGFyZWQtY29udGFjdC1jYXJkL3NoYXJlZC1jb250YWN0LWNhcmQuc2VydmljZSc7XG5leHBvcnQge1NsaXAzOVNlcnZpY2UgYXMgybVpfSBmcm9tICcuL2xpYi9zbGlwMzkvc2xpcDM5LnNlcnZpY2UnO1xuZXhwb3J0IHtUcEFzc2VtYmx5Q29udHJvbGxlciBhcyDJtWt9IGZyb20gJy4vbGliL3RwLWFzc2VtYmx5L3RwLWFzc2VtYmx5JztcbmV4cG9ydCB7VHBQYXNzd29yZFJlc2V0QXNzZW1ibHlDb250cm9sbGVyIGFzIMm1an0gZnJvbSAnLi9saWIvdHAtcGFzc3dvcmQtcmVzZXQvdHAtcGFzc3dvcmQtcmVzZXQuY29udHJvbGxlcic7XG5leHBvcnQge1RwUGFzc3dvcmRSZXNldFByaXZhdGVTZXJ2aWNlIGFzIMm1cH0gZnJvbSAnLi9saWIvdHAtcGFzc3dvcmQtcmVzZXQvdHAtcGFzc3dvcmQtcmVzZXQucHJpdmF0ZS5zZXJ2aWNlJztcbmV4cG9ydCB7VHJ1c3RlZFBhcnR5U2VydmljZSBhcyDJtW59IGZyb20gJy4vbGliL3RydXN0ZWQtcGFydHkvdHJ1c3RlZC1wYXJ0eS5zZXJ2aWNlJzsiXX0=
|
|
13
|
+
export { ScenarioAssemblyController as ɵn } from './lib/scenario/scenario.controller';
|
|
14
|
+
export { SharedContactCardService as ɵl } from './lib/shared-contact-card/shared-contact-card.service';
|
|
15
|
+
export { TpAssemblyController as ɵj } from './lib/tp-assembly/tp-assembly';
|
|
16
|
+
export { TpPasswordResetAssemblyController as ɵi } from './lib/tp-password-reset/tp-password-reset.controller';
|
|
17
|
+
export { TpPasswordResetPrivateService as ɵo } from './lib/tp-password-reset/tp-password-reset.private.service';
|
|
18
|
+
export { TrustedPartyService as ɵm } from './lib/trusted-party/trusted-party.service';
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlmZXJlYWR5LWNvcmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3NyYy9saWZlcmVhZHktY29yZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDO0FBRTdCLE9BQU8sRUFBQyxpQkFBaUIsSUFBSSxFQUFFLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQztBQUMxRSxPQUFPLEVBQUMsZ0JBQWdCLElBQUksRUFBRSxFQUFDLFNBQVMsSUFBSSxFQUFFLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQztBQUM1RSxPQUFPLEVBQUMsK0JBQStCLElBQUksRUFBRSxFQUFDLE1BQU0sK0RBQStELENBQUM7QUFDcEgsT0FBTyxFQUFDLGlCQUFpQixJQUFJLEVBQUUsRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBQzVFLE9BQU8sRUFBQyxpQkFBaUIsSUFBSSxFQUFFLEVBQUMsTUFBTSwrQkFBK0IsQ0FBQztBQUN0RSxPQUFPLEVBQUMsZUFBZSxJQUFJLEVBQUUsRUFBQyxNQUFNLDZCQUE2QixDQUFDO0FBQ2xFLE9BQU8sRUFBQyxjQUFjLElBQUksRUFBRSxFQUFDLE1BQU0sNEJBQTRCLENBQUM7QUFDaEUsT0FBTyxFQUFDLFVBQVUsSUFBSSxFQUFFLEVBQUMsTUFBTSx1QkFBdUIsQ0FBQztBQUN2RCxPQUFPLEVBQUMsMEJBQTBCLElBQUksRUFBRSxFQUFDLE1BQU0sb0NBQW9DLENBQUM7QUFDcEYsT0FBTyxFQUFDLHdCQUF3QixJQUFJLEVBQUUsRUFBQyxNQUFNLHVEQUF1RCxDQUFDO0FBQ3JHLE9BQU8sRUFBQyxvQkFBb0IsSUFBSSxFQUFFLEVBQUMsTUFBTSwrQkFBK0IsQ0FBQztBQUN6RSxPQUFPLEVBQUMsaUNBQWlDLElBQUksRUFBRSxFQUFDLE1BQU0sc0RBQXNELENBQUM7QUFDN0csT0FBTyxFQUFDLDZCQUE2QixJQUFJLEVBQUUsRUFBQyxNQUFNLDJEQUEyRCxDQUFDO0FBQzlHLE9BQU8sRUFBQyxtQkFBbUIsSUFBSSxFQUFFLEVBQUMsTUFBTSwyQ0FBMkMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcblxuZXhwb3J0IHtSdW5PdXRzaWRlQW5ndWxhciBhcyDJtWh9IGZyb20gJy4vbGliL19jb21tb24vcnVuLW91dHNpZGUtYW5ndWxhcic7XG5leHBvcnQge0xyR3JhcGhRTFNlcnZpY2UgYXMgybVmLExyU2VydmljZSBhcyDJtWt9IGZyb20gJy4vbGliL2FwaS9sci1ncmFwaHFsJztcbmV4cG9ydCB7VHBQYXNzd29yZFJlc2V0UHJvY2Vzc29yU2VydmljZSBhcyDJtWd9IGZyb20gJy4vbGliL2FwaS9xdWVyeS1wcm9jZXNzb3IvdHAtcGFzc3dvcmQtcmVzZXQtcHJvY2Vzc29yLnNlcnZpY2UnO1xuZXhwb3J0IHtFbmNyeXB0aW9uU2VydmljZSBhcyDJtWJ9IGZyb20gJy4vbGliL2VuY3J5cHRpb24vZW5jcnlwdGlvbi5zZXJ2aWNlJztcbmV4cG9ydCB7S2V5RmFjdG9yeVNlcnZpY2UgYXMgybVkfSBmcm9tICcuL2xpYi9rZXkva2V5LWZhY3Rvcnkuc2VydmljZSc7XG5leHBvcnQge0tleUdyYXBoU2VydmljZSBhcyDJtWF9IGZyb20gJy4vbGliL2tleS9rZXktZ3JhcGguc2VydmljZSc7XG5leHBvcnQge0tleU1ldGFTZXJ2aWNlIGFzIMm1ZX0gZnJvbSAnLi9saWIva2V5L2tleS1tZXRhLnNlcnZpY2UnO1xuZXhwb3J0IHtLZXlTZXJ2aWNlIGFzIMm1Y30gZnJvbSAnLi9saWIva2V5L2tleS5zZXJ2aWNlJztcbmV4cG9ydCB7U2NlbmFyaW9Bc3NlbWJseUNvbnRyb2xsZXIgYXMgybVufSBmcm9tICcuL2xpYi9zY2VuYXJpby9zY2VuYXJpby5jb250cm9sbGVyJztcbmV4cG9ydCB7U2hhcmVkQ29udGFjdENhcmRTZXJ2aWNlIGFzIMm1bH0gZnJvbSAnLi9saWIvc2hhcmVkLWNvbnRhY3QtY2FyZC9zaGFyZWQtY29udGFjdC1jYXJkLnNlcnZpY2UnO1xuZXhwb3J0IHtUcEFzc2VtYmx5Q29udHJvbGxlciBhcyDJtWp9IGZyb20gJy4vbGliL3RwLWFzc2VtYmx5L3RwLWFzc2VtYmx5JztcbmV4cG9ydCB7VHBQYXNzd29yZFJlc2V0QXNzZW1ibHlDb250cm9sbGVyIGFzIMm1aX0gZnJvbSAnLi9saWIvdHAtcGFzc3dvcmQtcmVzZXQvdHAtcGFzc3dvcmQtcmVzZXQuY29udHJvbGxlcic7XG5leHBvcnQge1RwUGFzc3dvcmRSZXNldFByaXZhdGVTZXJ2aWNlIGFzIMm1b30gZnJvbSAnLi9saWIvdHAtcGFzc3dvcmQtcmVzZXQvdHAtcGFzc3dvcmQtcmVzZXQucHJpdmF0ZS5zZXJ2aWNlJztcbmV4cG9ydCB7VHJ1c3RlZFBhcnR5U2VydmljZSBhcyDJtW19IGZyb20gJy4vbGliL3RydXN0ZWQtcGFydHkvdHJ1c3RlZC1wYXJ0eS5zZXJ2aWNlJzsiXX0=
|
|
@@ -4657,6 +4657,10 @@ PasswordService.ctorParameters = () => [
|
|
|
4657
4657
|
{ type: IdleService }
|
|
4658
4658
|
];
|
|
4659
4659
|
|
|
4660
|
+
const TP_PASSWORD_RESET_CLIENT_NONCE_LENGTH = 32;
|
|
4661
|
+
const TP_PASSWORD_RESET_SLIP39_PASSPHRASE = 'lifeready';
|
|
4662
|
+
const TP_PASSWORD_RESET_USERNAME_SUFFIX = '.tp_password_reset';
|
|
4663
|
+
|
|
4660
4664
|
class SecretShare {
|
|
4661
4665
|
constructor(assembly = 0, subAssembly = 0, mnemonics = '') {
|
|
4662
4666
|
this.assembly = assembly;
|
|
@@ -4820,10 +4824,6 @@ Slip39Service.decorators = [
|
|
|
4820
4824
|
},] }
|
|
4821
4825
|
];
|
|
4822
4826
|
|
|
4823
|
-
const TP_PASSWORD_RESET_CLIENT_NONCE_LENGTH = 32;
|
|
4824
|
-
const TP_PASSWORD_RESET_SLIP39_PASSPHRASE = 'lifeready';
|
|
4825
|
-
const TP_PASSWORD_RESET_USERNAME_SUFFIX = '.tp_password_reset';
|
|
4826
|
-
|
|
4827
4827
|
const TpsKeysQuery = gqlTyped `
|
|
4828
4828
|
query TpsKeysQuery($ids: [ID]) {
|
|
4829
4829
|
tps(id_In: $ids) {
|
|
@@ -5482,7 +5482,7 @@ const initialiseAuth = (authService) => {
|
|
|
5482
5482
|
return () => authService.initialise();
|
|
5483
5483
|
};
|
|
5484
5484
|
class LifeReadyAuthService {
|
|
5485
|
-
constructor(config, auth, keyFactory, keyService, profileService, keyGraphService, passwordService, idleService, lrGraphQL, tpPasswordResetProcessorService, persistService, encryptionService,
|
|
5485
|
+
constructor(config, auth, keyFactory, keyService, profileService, keyGraphService, passwordService, idleService, lrGraphQL, tpPasswordResetProcessorService, persistService, encryptionService, assemblyController) {
|
|
5486
5486
|
this.config = config;
|
|
5487
5487
|
this.auth = auth;
|
|
5488
5488
|
this.keyFactory = keyFactory;
|
|
@@ -5495,7 +5495,6 @@ class LifeReadyAuthService {
|
|
|
5495
5495
|
this.tpPasswordResetProcessorService = tpPasswordResetProcessorService;
|
|
5496
5496
|
this.persistService = persistService;
|
|
5497
5497
|
this.encryptionService = encryptionService;
|
|
5498
|
-
this.slip39Service = slip39Service;
|
|
5499
5498
|
this.assemblyController = assemblyController;
|
|
5500
5499
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
5501
5500
|
this.hubSubject = new ReplaySubject(1);
|
|
@@ -5915,7 +5914,7 @@ class LifeReadyAuthService {
|
|
|
5915
5914
|
});
|
|
5916
5915
|
}
|
|
5917
5916
|
}
|
|
5918
|
-
LifeReadyAuthService.ɵprov = ɵɵdefineInjectable({ factory: function LifeReadyAuthService_Factory() { return new LifeReadyAuthService(ɵɵinject(LR_CONFIG), ɵɵinject(AuthClass), ɵɵinject(KeyFactoryService), ɵɵinject(KeyService), ɵɵinject(ProfileService), ɵɵinject(KeyGraphService), ɵɵinject(PasswordService), ɵɵinject(IdleService), ɵɵinject(LrGraphQLService), ɵɵinject(TpPasswordResetProcessorService), ɵɵinject(PersistService), ɵɵinject(EncryptionService), ɵɵinject(
|
|
5917
|
+
LifeReadyAuthService.ɵprov = ɵɵdefineInjectable({ factory: function LifeReadyAuthService_Factory() { return new LifeReadyAuthService(ɵɵinject(LR_CONFIG), ɵɵinject(AuthClass), ɵɵinject(KeyFactoryService), ɵɵinject(KeyService), ɵɵinject(ProfileService), ɵɵinject(KeyGraphService), ɵɵinject(PasswordService), ɵɵinject(IdleService), ɵɵinject(LrGraphQLService), ɵɵinject(TpPasswordResetProcessorService), ɵɵinject(PersistService), ɵɵinject(EncryptionService), ɵɵinject(TpPasswordResetAssemblyController)); }, token: LifeReadyAuthService, providedIn: "root" });
|
|
5919
5918
|
LifeReadyAuthService.decorators = [
|
|
5920
5919
|
{ type: Injectable, args: [{
|
|
5921
5920
|
providedIn: 'root',
|
|
@@ -5934,7 +5933,6 @@ LifeReadyAuthService.ctorParameters = () => [
|
|
|
5934
5933
|
{ type: TpPasswordResetProcessorService },
|
|
5935
5934
|
{ type: PersistService },
|
|
5936
5935
|
{ type: EncryptionService },
|
|
5937
|
-
{ type: Slip39Service },
|
|
5938
5936
|
{ type: TpPasswordResetAssemblyController }
|
|
5939
5937
|
];
|
|
5940
5938
|
|
|
@@ -12141,6 +12139,33 @@ TpPasswordResetRequestService = __decorate([
|
|
|
12141
12139
|
})
|
|
12142
12140
|
], TpPasswordResetRequestService);
|
|
12143
12141
|
|
|
12142
|
+
const COGNITO_LOCALSTORAGE_PREFIX = 'CognitoIdentityServiceProvider';
|
|
12143
|
+
/**
|
|
12144
|
+
* Remove all keys in localstorage with matching prefix.
|
|
12145
|
+
* A prefix must be specified. If you want to remove everything, then just use localStorage.clear().
|
|
12146
|
+
*
|
|
12147
|
+
* @param prefix Keys with this prefix will be removed.
|
|
12148
|
+
*/
|
|
12149
|
+
function clearLocalStorage(prefix) {
|
|
12150
|
+
if (!prefix) {
|
|
12151
|
+
throw new LrBadArgumentException('You must specify a non empty prefix.');
|
|
12152
|
+
}
|
|
12153
|
+
// Remove all persisted session variables
|
|
12154
|
+
Object.keys(localStorage).forEach((key) => {
|
|
12155
|
+
if (key.startsWith(prefix)) {
|
|
12156
|
+
localStorage.removeItem(key);
|
|
12157
|
+
}
|
|
12158
|
+
});
|
|
12159
|
+
}
|
|
12160
|
+
/**
|
|
12161
|
+
* Clear all items related to cognito in localstorage.
|
|
12162
|
+
* The remember device function sometimes interferes with creating new users
|
|
12163
|
+
* on TP based password reset.
|
|
12164
|
+
*/
|
|
12165
|
+
function clearCognitoLocalStorage() {
|
|
12166
|
+
clearLocalStorage(COGNITO_LOCALSTORAGE_PREFIX);
|
|
12167
|
+
}
|
|
12168
|
+
|
|
12144
12169
|
let TpPasswordResetUserService = class TpPasswordResetUserService extends LrService {
|
|
12145
12170
|
constructor(ngZone, injector, config, keyFactory, encryptionService, passwordService, http, auth) {
|
|
12146
12171
|
super(injector);
|
|
@@ -12177,6 +12202,9 @@ let TpPasswordResetUserService = class TpPasswordResetUserService extends LrServ
|
|
|
12177
12202
|
}
|
|
12178
12203
|
requestReset(password, claimId, claimToken) {
|
|
12179
12204
|
return __awaiter(this, void 0, void 0, function* () {
|
|
12205
|
+
// Clearing all localstorage data because cognito has the "remember device" functionality which sometimes
|
|
12206
|
+
// does not work properly. Clearing localstorage seems to solve this issue.
|
|
12207
|
+
clearCognitoLocalStorage();
|
|
12180
12208
|
// Generate the key materials
|
|
12181
12209
|
const passKeyBundle = yield this.passwordService.createPassKeyBundle(password);
|
|
12182
12210
|
const masterKey = yield this.keyFactory.createKey();
|
|
@@ -12704,5 +12732,5 @@ TwoFactorService.ctorParameters = () => [
|
|
|
12704
12732
|
* Generated bundle index. Do not edit.
|
|
12705
12733
|
*/
|
|
12706
12734
|
|
|
12707
|
-
export { AccessLevel, AccessRoleChoice, AccessRoleMethodChoice, ApiContactCard, ApiCurrentUser, ArchiveDirectoryMutation, CancelUserDeleteMutation, Category, CategoryFields, CategoryFilter, CategoryMetaService, CategoryService, ClaimApproverState, ClaimState, CognitoChallengeUser, CommonProcessorsService, CompleteOtkMutation, Config, ContactCard2Service, ContactCardAddress, ContactCardName, CreateCategoryMutation, CreateContactCardMutation$1 as CreateContactCardMutation, CreateFileMutation, CreateFileQuery, CreateLbopQuery, CreateRecordContainerMutation, CreateRecordMutation, CreateVaultMutation, CurrentCategory, CurrentUser, CurrentUserKey, CurrentUserQuery, CurrentUserSharedKeyQuery, DEFAULT_BREADCRUMB_DEPTH, DEFAULT_DESCENDANTS_DEPTH, DefaultCategory, DefaultProcessorOptions, DefaultVaultFilter, DeleteCategoryMutation, DeleteFileMutation, DeleteLbopQuery, DeleteRecordMutation, DirectoryQuery, DirectoryType, FeatureAction, Features, FetchKeyGraphField, FileOperationField, FileQuery, FileType, FileUploadService, GetCategoriesQuery, GetCategoryKeyIdQuery, GetCategoryQuery, GetMySharedCategoriesQuery, GetRecordQuery, GetRootDirectoryIdsQuery, GetTrustedPartyCategoriesQuery, GetVaultsQuery, IdleService, InitiateOtkMutation, Item2Service, KeyExchange2Service, KeyExchangeFields, KeyExchangeMode, KeyExchangeOtkState, KeyExchangeQuery, KeyExchangeService, KeyExchangeState, KeyExchangeTokenQuery, KeyExchangesQuery, KeyGraphField, KeyGraphFragment, LR_CONFIG, LbopQuery, LbopService, LbopsQuery, LifeReadyAuthService, LifeReadyModule, LinkTypeField, LoadedCategoryTree, LockService, LockState, LoginHistoryQuery, LoginResult, LrApiErrorCode, LrApolloService, LrAuthException, LrBadArgumentException, LrBadLogicException, LrBadRequestException, LrBadStateException, LrCodeMismatchException, LrConcurrentAccessException, LrEncryptionException, LrError, LrErrorCode, LrException, LrExpiredCodeException, LrExpiredException, LrGraphQLService, LrLockedException, LrMergedMutation, LrMutation, LrMutationBase, LrNotFoundException, LrRecord, LrService, LrSuspiciousException, LrUnsupportedException, MainContactCard, MainContactCardFields, MainContactCardPlainFields, MainContactCardProperty, MessageService, MoveDirectoryQuery, MoveFileQuery, NewAttachment, NewCategory, NewOrUpdatedAttachment, NewRecord, NotificationService, OtkState, OwnerPlainDataJson, PassIdpApiResult, PasswordChangeStatus, PasswordCheck, PasswordService, PermissionChoice, PersistService, Plan, PlanService, PlanState, ProfileDetailsService, ProfileService, QueryProcessorService, RecordAttachment, RecordAttachmentFilter, RecordAttachmentService, RecordContentFilter, RecordField, RecordFieldType, RecordFilter, RecordService, RecordType, RecordTypeField, RecordTypeFieldOption, RecordTypeService, RecordTypeSummary, RecoveryStatus, RegisterResult, RegisterService, RequestUserDeleteMutation, RespondOtkMutation, RevertFileQuery, ScenarioLastClaimState, ScenarioService, ScenarioState, ServerConfigService, ServerTimeQuery, SharedAccess, SharedContactCard2Service, StripeBillingPortalSession, StripeCheckoutSession, Subscription, TimeService, TpAssemblyState, TpClaimApproverState, TpClaimState, TpPasswordResetRequestService, TpPasswordResetService, TpPasswordResetUserService, TrustedParty2Service, TrustedPartyDetails, TwoFactorService, UnarchiveDirectoryMutation, UpdateCategoryMutation, UpdateContactCardMutation$1 as UpdateContactCardMutation, UpdateFileQuery, UpdateLbopQuery, UpdateRecordContainerMutation, UpdateRecordMutation, UpdatedCategory, UpdatedRecord, UserDeleteState, UserPlan, UserService, UserSharedKeyFields, Vault, VaultCategory, VaultFields, VaultRecord, VaultRecordType, WebCryptoService, awsFetch, configureAmplifyAuth, configureApollo, fragmentSpreadAstSelection, gqlTyped, handleApolloError, handleCognitoCallback, initialiseAuth, mapEdges, mapUserPlans, parentCategoriesField, processConnection, throwClaimIdMismatch, throwClaimNotApproved, ɵ0, KeyGraphService as ɵa, EncryptionService as ɵb, KeyService as ɵc, KeyFactoryService as ɵd, KeyMetaService as ɵe, LrGraphQLService as ɵf, TpPasswordResetProcessorService as ɵg, RunOutsideAngular as ɵh,
|
|
12735
|
+
export { AccessLevel, AccessRoleChoice, AccessRoleMethodChoice, ApiContactCard, ApiCurrentUser, ArchiveDirectoryMutation, CancelUserDeleteMutation, Category, CategoryFields, CategoryFilter, CategoryMetaService, CategoryService, ClaimApproverState, ClaimState, CognitoChallengeUser, CommonProcessorsService, CompleteOtkMutation, Config, ContactCard2Service, ContactCardAddress, ContactCardName, CreateCategoryMutation, CreateContactCardMutation$1 as CreateContactCardMutation, CreateFileMutation, CreateFileQuery, CreateLbopQuery, CreateRecordContainerMutation, CreateRecordMutation, CreateVaultMutation, CurrentCategory, CurrentUser, CurrentUserKey, CurrentUserQuery, CurrentUserSharedKeyQuery, DEFAULT_BREADCRUMB_DEPTH, DEFAULT_DESCENDANTS_DEPTH, DefaultCategory, DefaultProcessorOptions, DefaultVaultFilter, DeleteCategoryMutation, DeleteFileMutation, DeleteLbopQuery, DeleteRecordMutation, DirectoryQuery, DirectoryType, FeatureAction, Features, FetchKeyGraphField, FileOperationField, FileQuery, FileType, FileUploadService, GetCategoriesQuery, GetCategoryKeyIdQuery, GetCategoryQuery, GetMySharedCategoriesQuery, GetRecordQuery, GetRootDirectoryIdsQuery, GetTrustedPartyCategoriesQuery, GetVaultsQuery, IdleService, InitiateOtkMutation, Item2Service, KeyExchange2Service, KeyExchangeFields, KeyExchangeMode, KeyExchangeOtkState, KeyExchangeQuery, KeyExchangeService, KeyExchangeState, KeyExchangeTokenQuery, KeyExchangesQuery, KeyGraphField, KeyGraphFragment, LR_CONFIG, LbopQuery, LbopService, LbopsQuery, LifeReadyAuthService, LifeReadyModule, LinkTypeField, LoadedCategoryTree, LockService, LockState, LoginHistoryQuery, LoginResult, LrApiErrorCode, LrApolloService, LrAuthException, LrBadArgumentException, LrBadLogicException, LrBadRequestException, LrBadStateException, LrCodeMismatchException, LrConcurrentAccessException, LrEncryptionException, LrError, LrErrorCode, LrException, LrExpiredCodeException, LrExpiredException, LrGraphQLService, LrLockedException, LrMergedMutation, LrMutation, LrMutationBase, LrNotFoundException, LrRecord, LrService, LrSuspiciousException, LrUnsupportedException, MainContactCard, MainContactCardFields, MainContactCardPlainFields, MainContactCardProperty, MessageService, MoveDirectoryQuery, MoveFileQuery, NewAttachment, NewCategory, NewOrUpdatedAttachment, NewRecord, NotificationService, OtkState, OwnerPlainDataJson, PassIdpApiResult, PasswordChangeStatus, PasswordCheck, PasswordService, PermissionChoice, PersistService, Plan, PlanService, PlanState, ProfileDetailsService, ProfileService, QueryProcessorService, RecordAttachment, RecordAttachmentFilter, RecordAttachmentService, RecordContentFilter, RecordField, RecordFieldType, RecordFilter, RecordService, RecordType, RecordTypeField, RecordTypeFieldOption, RecordTypeService, RecordTypeSummary, RecoveryStatus, RegisterResult, RegisterService, RequestUserDeleteMutation, RespondOtkMutation, RevertFileQuery, ScenarioLastClaimState, ScenarioService, ScenarioState, ServerConfigService, ServerTimeQuery, SharedAccess, SharedContactCard2Service, StripeBillingPortalSession, StripeCheckoutSession, Subscription, TimeService, TpAssemblyState, TpClaimApproverState, TpClaimState, TpPasswordResetRequestService, TpPasswordResetService, TpPasswordResetUserService, TrustedParty2Service, TrustedPartyDetails, TwoFactorService, UnarchiveDirectoryMutation, UpdateCategoryMutation, UpdateContactCardMutation$1 as UpdateContactCardMutation, UpdateFileQuery, UpdateLbopQuery, UpdateRecordContainerMutation, UpdateRecordMutation, UpdatedCategory, UpdatedRecord, UserDeleteState, UserPlan, UserService, UserSharedKeyFields, Vault, VaultCategory, VaultFields, VaultRecord, VaultRecordType, WebCryptoService, awsFetch, configureAmplifyAuth, configureApollo, fragmentSpreadAstSelection, gqlTyped, handleApolloError, handleCognitoCallback, initialiseAuth, mapEdges, mapUserPlans, parentCategoriesField, processConnection, throwClaimIdMismatch, throwClaimNotApproved, ɵ0, KeyGraphService as ɵa, EncryptionService as ɵb, KeyService as ɵc, KeyFactoryService as ɵd, KeyMetaService as ɵe, LrGraphQLService as ɵf, TpPasswordResetProcessorService as ɵg, RunOutsideAngular as ɵh, TpPasswordResetAssemblyController as ɵi, TpAssemblyController as ɵj, LrService as ɵk, SharedContactCardService as ɵl, TrustedPartyService as ɵm, ScenarioAssemblyController as ɵn, TpPasswordResetPrivateService as ɵo };
|
|
12708
12736
|
//# sourceMappingURL=lifeready-core.js.map
|