@lifeready/core 5.0.10 → 5.0.11

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.
@@ -22,7 +22,7 @@ import { CompleteTpPasswordResetRequestMutation, CreateTpAssemblyKeyChallengeMut
22
22
  import { KcBadRequestException, KcBadStateException, KcConcurrentAccessException, KcInternalErrorException, } from '../_common/exceptions';
23
23
  import { KeyContainer } from '../_common/key';
24
24
  import { RunOutsideAngular } from '../_common/run-outside-angular';
25
- import { CurrentUserQuery, } from './auth2.gql.private';
25
+ import { CurrentUserQuery, ResetUserQuery, } from './auth2.gql.private';
26
26
  import { CognitoChallengeName, PasswordChangeStatus, RecoveryStatus, } from './auth2.types';
27
27
  import * as i0 from "@angular/core";
28
28
  import * as i1 from "@angular/common/http";
@@ -180,7 +180,7 @@ let Auth2Service = Auth2Service_1 = class Auth2Service extends LrService {
180
180
  fetchResetUser() {
181
181
  return __awaiter(this, void 0, void 0, function* () {
182
182
  return (yield this.api.query({
183
- query: CurrentUserQuery,
183
+ query: ResetUserQuery,
184
184
  processorOptions: {
185
185
  hasKeys: false,
186
186
  },
@@ -363,7 +363,6 @@ let Auth2Service = Auth2Service_1 = class Auth2Service extends LrService {
363
363
  const passKey = (yield this.keyFactoryService.derivePassKey(Object.assign({ password }, userKeys.passKey.passKeyParams))).jwk;
364
364
  yield this.idleService.persistMasterKey(yield this.keyGraphService.unwrapWithPassKey(userKeys.passKey.id, passKey, userKeys.masterKey.id));
365
365
  }
366
- yield this.keyGraphService.populateKeys(userKeys);
367
366
  });
368
367
  }
369
368
  loadUser(cognitoUser, password) {
@@ -386,6 +385,8 @@ let Auth2Service = Auth2Service_1 = class Auth2Service extends LrService {
386
385
  password,
387
386
  sessionEncryptionKey: currentUser.sessionEncryptionKey,
388
387
  });
388
+ // Regular user populates all keys
389
+ yield this.keyGraphService.populateKeys(currentUser.currentUserKey);
389
390
  const { username } = currentUser;
390
391
  const userAttributes = yield this.cognito.userAttributes(cognitoUser);
391
392
  return {
@@ -399,18 +400,22 @@ let Auth2Service = Auth2Service_1 = class Auth2Service extends LrService {
399
400
  loadResetUser(cognitoUser, password) {
400
401
  return __awaiter(this, void 0, void 0, function* () {
401
402
  const resetUser = yield this.fetchResetUser();
402
- this.loadUserKeys({
403
- userKeys: {
404
- passKey: {
405
- id: resetUser.passKey.id,
406
- },
407
- masterKey: {
408
- id: resetUser.masterKey.id,
409
- },
403
+ const userKeys = {
404
+ passKey: {
405
+ id: resetUser.passKey.id,
406
+ passKeyParams: resetUser.passKey.passKeyParams,
410
407
  },
408
+ masterKey: {
409
+ id: resetUser.masterKey.id,
410
+ },
411
+ };
412
+ yield this.loadUserKeys({
413
+ userKeys,
411
414
  password,
412
415
  sessionEncryptionKey: resetUser.sessionEncryptionKey,
413
416
  });
417
+ // Reset user only sets a subset of keys
418
+ yield this.keyService.setKeys(userKeys);
414
419
  const { username } = resetUser;
415
420
  const userAttributes = yield this.cognito.userAttributes(cognitoUser);
416
421
  return {
@@ -588,4 +593,4 @@ Auth2Service = Auth2Service_1 = __decorate([
588
593
  })
589
594
  ], Auth2Service);
590
595
  export { Auth2Service };
591
- //# 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 { SetSessionEncryptionKeyMutation } from '../auth/auth.gql';\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  ResetUserQueryResult,\n} from './auth2.gql.private';\nimport {\n  AuthUser,\n  CognitoChallengeName,\n  LoginChallenge,\n  LoginOptions,\n  LoginResult,\n  LogoutListener,\n  LrCognitoUser,\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: CurrentUserQuery,\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\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    await this.keyGraphService.populateKeys(userKeys);\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    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    this.loadUserKeys({\n      userKeys: {\n        passKey: {\n          id: resetUser.passKey.id,\n        },\n        masterKey: {\n          id: resetUser.masterKey.id,\n        },\n      },\n      password,\n      sessionEncryptionKey: resetUser.sessionEncryptionKey,\n    });\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"]}
596
+ //# 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 { SetSessionEncryptionKeyMutation } from '../auth/auth.gql';\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} from './auth2.gql.private';\nimport {\n  AuthUser,\n  CognitoChallengeName,\n  LoginChallenge,\n  LoginOptions,\n  LoginResult,\n  LogoutListener,\n  LrCognitoUser,\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"]}
@@ -28,7 +28,7 @@ export class KeyGraphService {
28
28
  }
29
29
  populateKeys(userKey) {
30
30
  return __awaiter(this, void 0, void 0, function* () {
31
- this.keyService.populateKeys({
31
+ this.keyService.setKeys({
32
32
  passKey: userKey.passKey,
33
33
  masterKey: yield this.keyService.loadMasterKey(userKey.masterKey.id),
34
34
  rootKey: yield this.unwrapKey(userKey.masterKey.id, userKey.rootKey.id),
@@ -292,4 +292,4 @@ KeyGraphService.ctorParameters = () => [
292
292
  { type: KeyService },
293
293
  { type: KeyFactoryService }
294
294
  ];
295
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"key-graph.service.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/key/key-graph.service.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { Injectable } from '@angular/core';\nimport graphlib, { Graph } from '@dagrejs/graphlib';\nimport _ from 'lodash';\nimport { JWK } from 'node-jose';\nimport { JSONObject } from '../api/types';\nimport {\n  asJwk,\n  DecryptOptions,\n  EncryptionService,\n  isSymmetricKey,\n} from '../encryption/encryption.service';\nimport {\n  KcBadArgumentException,\n  KcBadStateException,\n  KcEncryptionException,\n  KcNotFoundException,\n} from '../_common/exceptions';\nimport {\n  KeyFactoryService,\n  KeyFactoryService as KFS,\n} from './key-factory.service';\nimport { KeyService, UserKeys } from './key.service';\nimport {\n  Key,\n  KeyGraphEdge,\n  KeyGraphEdgeType,\n  KeyGraphNode,\n  KeyGraphNodeType,\n  KeyGraphResponse,\n  PassKey,\n} from './key.types';\n\nexport interface GraphKey extends Key {\n  task?: Promise<any>;\n}\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class KeyGraphService {\n  private graph: Graph;\n  // private keyCache: {\n  //   [id: string]: Key;\n  // };\n\n  constructor(\n    private encryptionService: EncryptionService,\n    private keyService: KeyService,\n    private keyFactory: KeyFactoryService\n  ) {\n    this.purgeKeys();\n  }\n\n  purgeKeys() {\n    this.graph = new Graph();\n    // this.keyCache = null;\n  }\n\n  async populateKeys(userKey: UserKeys) {\n    this.keyService.populateKeys({\n      passKey: userKey.passKey,\n      masterKey: await this.keyService.loadMasterKey(userKey.masterKey.id),\n      rootKey: await this.unwrapKey(userKey.masterKey.id, userKey.rootKey.id),\n      pxk: await this.unwrapKey(userKey.masterKey.id, userKey.pxk.id),\n      sigPxk: await this.unwrapKey(userKey.masterKey.id, userKey.sigPxk.id),\n    });\n  }\n\n  hasKey(keyId: string) {\n    return !!this.graph.node(keyId);\n  }\n\n  private getNode(id, type): GraphKey | PassKey {\n    const node = this.graph.node(id);\n    if (!node) {\n      throw new KcNotFoundException(\n        `Key graphs does not contain key id: ${id}`\n      );\n    }\n    if (node.type !== type) {\n      throw new KcBadStateException(`Key with id ${id} is not of type ${type}`);\n    }\n    return node.data;\n  }\n\n  key(id): GraphKey {\n    return this.getNode(id, KeyGraphNodeType.Key);\n  }\n\n  passKey(id): PassKey {\n    return this.getNode(id, KeyGraphNodeType.PassKey);\n  }\n\n  addKeys(src: KeyGraphResponse) {\n    // Keys\n    if (src.keys) {\n      // What key graph returns can not be customized. So keys are essentially immutable.\n      // Therefore, if a key exists, there's no reason to update it.\n      for (const key of src.keys) {\n        // Note using Relay global id allows us to not worry about clashing node id\n        if (this.graph.hasNode(key.id)) {\n          continue;\n        }\n\n        const node: KeyGraphNode = {\n          type: KeyGraphNodeType.Key,\n          data: _.cloneDeep(key),\n        };\n\n        this.graph.setNode(key.id, node);\n      }\n    }\n\n    // KeyLinks\n    if (src.keyLinks) {\n      for (const keyLink of src.keyLinks) {\n        if (this.graph.hasEdge(keyLink.wrappingKeyId, keyLink.keyId)) {\n          continue;\n        }\n\n        const edge: KeyGraphEdge = {\n          type: KeyGraphEdgeType.KeyLink,\n          data: _.cloneDeep(keyLink),\n        };\n        // Edge goes from wrapping key to wrapped key.\n        this.graph.setEdge(keyLink.wrappingKeyId, keyLink.keyId, edge);\n      }\n    }\n\n    // PassKeyLinks\n    if (src.passKeyLinks) {\n      for (const passKeyLink of src.passKeyLinks) {\n        if (this.graph.hasEdge(passKeyLink.passKeyId, passKeyLink.keyId)) {\n          continue;\n        }\n\n        const edge: KeyGraphEdge = {\n          type: KeyGraphEdgeType.PassKeyLink,\n          data: _.cloneDeep(passKeyLink),\n        };\n        // Edge goes from wrapping key to wrapped key.\n        this.graph.setEdge(passKeyLink.passKeyId, passKeyLink.keyId, edge);\n      }\n    }\n\n    // The graph is the single source of truth. These are lazily calculated.\n    // this.keyCache = null;\n  }\n\n  tracePath(distances, keyId: string): KeyGraphEdge[] {\n    // The node label is the same as the id of the key nodes.\n    const ret: KeyGraphEdge[] = [];\n    let node = keyId;\n    if (!distances[node].predecessor) {\n      return null;\n    }\n\n    while (distances[node].predecessor) {\n      const child = distances[node].predecessor;\n      ret.push(this.graph.edge(child, node));\n      node = child;\n    }\n\n    // After reverse, the first element is the passkey\n    ret.reverse();\n\n    return ret;\n  }\n\n  getPath(knownKeyId: string, keyId: string): KeyGraphEdge[] {\n    if (!knownKeyId || typeof knownKeyId !== 'string') {\n      throw new KcEncryptionException(\n        `Param knownKeyId wrong format: ${knownKeyId}`\n      );\n    }\n    if (!keyId || typeof keyId !== 'string') {\n      throw new KcEncryptionException(`Param keyId wrong format: ${keyId}`);\n    }\n\n    // => { A: { distance: 0 },\n    //      B: { distance: 6, predecessor: 'C' },\n    //      C: { distance: 4, predecessor: 'A' },\n    //      D: { distance: 2, predecessor: 'A' },\n    //      E: { distance: 8, predecessor: 'F' },\n    //      F: { distance: 4, predecessor: 'D' } }\n    const distances = graphlib.alg.dijkstra(this.graph, knownKeyId);\n\n    // Trace path from keyId to knownKeyId\n    return this.tracePath(distances, keyId);\n  }\n\n  async getJwkKey(\n    keyOrId: string | Key,\n    getKeyIdCallback?: () => Promise<string> | string\n  ): Promise<JWK.Key> {\n    return (await this.getKey(keyOrId, getKeyIdCallback)).jwk;\n  }\n\n  // We assume that when a keyId is fetched, the key graph\n  // for the key is also returned and merged into the client-side\n  // key graph. By insisting a keyId is returned instead of the\n  // actual key we ensure key-graph is consistent.\n  async getKey(\n    keyOrId: string | Key,\n    getKeyIdCallback?: () => Promise<string> | string\n  ): Promise<Key> {\n    let keyId = typeof keyOrId === 'string' ? keyOrId : keyOrId?.id;\n\n    if (!this.hasKey(keyId) && getKeyIdCallback) {\n      keyId = await getKeyIdCallback();\n    }\n    // else, continue and let it fail.\n\n    const key = this.key(keyId);\n    if (key.jwk) {\n      return key;\n    } else {\n      return this.unwrapKey(this.keyService.currentMasterKey.id, keyId);\n    }\n  }\n\n  private async _unwrapLink(wrappingKey, link, dstKey) {\n    const wrappedKey = JSON.parse(link.data.wrappedKey);\n    // Signatures of keys contain the key itself. This way we only need\n    // to access the KeyLinks to decrypt/verify keys.\n    let nextRawKey;\n    if (wrappedKey.signatures) {\n      nextRawKey = await this.encryptionService.verify(wrappingKey, wrappedKey);\n    } else {\n      nextRawKey = await this.encryptionService.decrypt(\n        wrappingKey,\n        wrappedKey\n      );\n    }\n    dstKey.jwk = await KFS.asKey(nextRawKey);\n    dstKey.task = null;\n  }\n\n  private async _unwrap(key: JWK.Key, path: KeyGraphEdge[]): Promise<JWK.Key> {\n    for (const link of path) {\n      const dstKey = this.key(link.data.keyId);\n      if (dstKey.jwk) {\n        key = dstKey.jwk;\n        continue;\n      }\n\n      if (!dstKey.task) {\n        dstKey.task = this._unwrapLink(key, link, dstKey);\n      }\n\n      await dstKey.task;\n      key = dstKey.jwk;\n    }\n\n    return key;\n  }\n\n  public async unwrapWithPassKey(\n    passKeyId: string,\n    passKey: JWK.Key,\n    keyId: string\n  ): Promise<Key> {\n    // Get path of the directory key.\n    const path = this.getPath(passKeyId, keyId);\n\n    return {\n      id: keyId,\n      jwk: await this._unwrap(passKey, path),\n    };\n  }\n\n  async unwrapKey(masterKeyId: string, keyId: string): Promise<Key> {\n    // The first key should be a masterKey\n    const masterKey = await this.keyService.loadMasterKey(masterKeyId);\n\n    if (masterKeyId === keyId) {\n      return masterKey;\n    }\n\n    // Get path of the directory key.\n    const path = this.getPath(masterKey.id, keyId);\n\n    return {\n      id: keyId,\n      jwk: await this._unwrap(masterKey.jwk, path),\n    };\n  }\n\n  async decryptFromString<T>(\n    keyOrId: string | Key,\n    cipherData: string,\n    options?: DecryptOptions\n  ): Promise<T> {\n    if (cipherData) {\n      const key = await this.getJwkKey(keyOrId);\n      return (await this.encryptionService.decrypt(\n        key,\n        JSON.parse(cipherData),\n        options\n      )) as any;\n    }\n    return null;\n  }\n\n  async decryptFile(keyId: string, file: any): Promise<any> {\n    const key = await this.getJwkKey(keyId);\n    return (await this.encryptionService.decrypt(key, file, {\n      payloadType: 'ArrayBuffer',\n    })) as any;\n  }\n\n  // TODO rename this to encrypt() and use as the most common usecase\n  async encryptToString(\n    key: string | Key | JWK.Key,\n    content: any\n  ): Promise<string> {\n    // Empty string should be encrypted since you want to clear the field.\n    // Null is not encrypted because it's not valid JSON in the old JSON spec. Use\n    // empty string instead. It'll function as a logic false as well.\n    // Note that passing in empty string means it'll be encrypted which verifies\n    // it's integrity. But we still want to have a way to set the DB field\n    // to NULL, so we explicitly return null when content == null. A null\n    // variable in graphql mutation on KC server clears the field to NULL.\n    if (content == null) {\n      return null;\n    }\n\n    const jwk = asJwk(key) || (await this.getJwkKey(key as string | Key));\n    return this.encryptionService.encryptToString(jwk, content);\n  }\n\n  // Wraps a symmetric encryption key.\n  // Throws exception if wrapping public keys.\n  async wrapKey(\n    wrappingKey: string | Key | JWK.Key,\n    key: JWK.Key\n  ): Promise<string> {\n    if (!isSymmetricKey(key)) {\n      throw new KcBadArgumentException(\n        'Only allowing wrapping of symmetric keys.'\n      );\n    }\n\n    return this.encryptToString(wrappingKey, key.toJSON(true));\n  }\n\n  // TODO\n  // async wrapPublicKey<T>();\n  // async wrapPrivateKey<T>();\n\n  async encryptWithNewKey(wrappingKeyId: string, cipherClearJson: JSONObject) {\n    const key = await this.keyFactory.createKey();\n    const wrappedKey = await this.encryptToString(\n      wrappingKeyId,\n      key.toJSON(true)\n    );\n    const cipher = await this.encryptToString(key, cipherClearJson);\n\n    return {\n      key,\n      wrappingKeyId,\n      wrappedKey,\n      cipher,\n    };\n  }\n}\n"]}
295
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"key-graph.service.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/key/key-graph.service.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { Injectable } from '@angular/core';\nimport graphlib, { Graph } from '@dagrejs/graphlib';\nimport _ from 'lodash';\nimport { JWK } from 'node-jose';\nimport { JSONObject } from '../api/types';\nimport {\n  asJwk,\n  DecryptOptions,\n  EncryptionService,\n  isSymmetricKey,\n} from '../encryption/encryption.service';\nimport {\n  KcBadArgumentException,\n  KcBadStateException,\n  KcEncryptionException,\n  KcNotFoundException,\n} from '../_common/exceptions';\nimport {\n  KeyFactoryService,\n  KeyFactoryService as KFS,\n} from './key-factory.service';\nimport { KeyService, UserKeys } from './key.service';\nimport {\n  Key,\n  KeyGraphEdge,\n  KeyGraphEdgeType,\n  KeyGraphNode,\n  KeyGraphNodeType,\n  KeyGraphResponse,\n  PassKey,\n} from './key.types';\n\nexport interface GraphKey extends Key {\n  task?: Promise<any>;\n}\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class KeyGraphService {\n  private graph: Graph;\n  // private keyCache: {\n  //   [id: string]: Key;\n  // };\n\n  constructor(\n    private encryptionService: EncryptionService,\n    private keyService: KeyService,\n    private keyFactory: KeyFactoryService\n  ) {\n    this.purgeKeys();\n  }\n\n  purgeKeys() {\n    this.graph = new Graph();\n    // this.keyCache = null;\n  }\n\n  async populateKeys(userKey: UserKeys) {\n    this.keyService.setKeys({\n      passKey: userKey.passKey,\n      masterKey: await this.keyService.loadMasterKey(userKey.masterKey.id),\n      rootKey: await this.unwrapKey(userKey.masterKey.id, userKey.rootKey.id),\n      pxk: await this.unwrapKey(userKey.masterKey.id, userKey.pxk.id),\n      sigPxk: await this.unwrapKey(userKey.masterKey.id, userKey.sigPxk.id),\n    });\n  }\n\n  hasKey(keyId: string) {\n    return !!this.graph.node(keyId);\n  }\n\n  private getNode(id, type): GraphKey | PassKey {\n    const node = this.graph.node(id);\n    if (!node) {\n      throw new KcNotFoundException(\n        `Key graphs does not contain key id: ${id}`\n      );\n    }\n    if (node.type !== type) {\n      throw new KcBadStateException(`Key with id ${id} is not of type ${type}`);\n    }\n    return node.data;\n  }\n\n  key(id): GraphKey {\n    return this.getNode(id, KeyGraphNodeType.Key);\n  }\n\n  passKey(id): PassKey {\n    return this.getNode(id, KeyGraphNodeType.PassKey);\n  }\n\n  addKeys(src: KeyGraphResponse) {\n    // Keys\n    if (src.keys) {\n      // What key graph returns can not be customized. So keys are essentially immutable.\n      // Therefore, if a key exists, there's no reason to update it.\n      for (const key of src.keys) {\n        // Note using Relay global id allows us to not worry about clashing node id\n        if (this.graph.hasNode(key.id)) {\n          continue;\n        }\n\n        const node: KeyGraphNode = {\n          type: KeyGraphNodeType.Key,\n          data: _.cloneDeep(key),\n        };\n\n        this.graph.setNode(key.id, node);\n      }\n    }\n\n    // KeyLinks\n    if (src.keyLinks) {\n      for (const keyLink of src.keyLinks) {\n        if (this.graph.hasEdge(keyLink.wrappingKeyId, keyLink.keyId)) {\n          continue;\n        }\n\n        const edge: KeyGraphEdge = {\n          type: KeyGraphEdgeType.KeyLink,\n          data: _.cloneDeep(keyLink),\n        };\n        // Edge goes from wrapping key to wrapped key.\n        this.graph.setEdge(keyLink.wrappingKeyId, keyLink.keyId, edge);\n      }\n    }\n\n    // PassKeyLinks\n    if (src.passKeyLinks) {\n      for (const passKeyLink of src.passKeyLinks) {\n        if (this.graph.hasEdge(passKeyLink.passKeyId, passKeyLink.keyId)) {\n          continue;\n        }\n\n        const edge: KeyGraphEdge = {\n          type: KeyGraphEdgeType.PassKeyLink,\n          data: _.cloneDeep(passKeyLink),\n        };\n        // Edge goes from wrapping key to wrapped key.\n        this.graph.setEdge(passKeyLink.passKeyId, passKeyLink.keyId, edge);\n      }\n    }\n\n    // The graph is the single source of truth. These are lazily calculated.\n    // this.keyCache = null;\n  }\n\n  tracePath(distances, keyId: string): KeyGraphEdge[] {\n    // The node label is the same as the id of the key nodes.\n    const ret: KeyGraphEdge[] = [];\n    let node = keyId;\n    if (!distances[node].predecessor) {\n      return null;\n    }\n\n    while (distances[node].predecessor) {\n      const child = distances[node].predecessor;\n      ret.push(this.graph.edge(child, node));\n      node = child;\n    }\n\n    // After reverse, the first element is the passkey\n    ret.reverse();\n\n    return ret;\n  }\n\n  getPath(knownKeyId: string, keyId: string): KeyGraphEdge[] {\n    if (!knownKeyId || typeof knownKeyId !== 'string') {\n      throw new KcEncryptionException(\n        `Param knownKeyId wrong format: ${knownKeyId}`\n      );\n    }\n    if (!keyId || typeof keyId !== 'string') {\n      throw new KcEncryptionException(`Param keyId wrong format: ${keyId}`);\n    }\n\n    // => { A: { distance: 0 },\n    //      B: { distance: 6, predecessor: 'C' },\n    //      C: { distance: 4, predecessor: 'A' },\n    //      D: { distance: 2, predecessor: 'A' },\n    //      E: { distance: 8, predecessor: 'F' },\n    //      F: { distance: 4, predecessor: 'D' } }\n    const distances = graphlib.alg.dijkstra(this.graph, knownKeyId);\n\n    // Trace path from keyId to knownKeyId\n    return this.tracePath(distances, keyId);\n  }\n\n  async getJwkKey(\n    keyOrId: string | Key,\n    getKeyIdCallback?: () => Promise<string> | string\n  ): Promise<JWK.Key> {\n    return (await this.getKey(keyOrId, getKeyIdCallback)).jwk;\n  }\n\n  // We assume that when a keyId is fetched, the key graph\n  // for the key is also returned and merged into the client-side\n  // key graph. By insisting a keyId is returned instead of the\n  // actual key we ensure key-graph is consistent.\n  async getKey(\n    keyOrId: string | Key,\n    getKeyIdCallback?: () => Promise<string> | string\n  ): Promise<Key> {\n    let keyId = typeof keyOrId === 'string' ? keyOrId : keyOrId?.id;\n\n    if (!this.hasKey(keyId) && getKeyIdCallback) {\n      keyId = await getKeyIdCallback();\n    }\n    // else, continue and let it fail.\n\n    const key = this.key(keyId);\n    if (key.jwk) {\n      return key;\n    } else {\n      return this.unwrapKey(this.keyService.currentMasterKey.id, keyId);\n    }\n  }\n\n  private async _unwrapLink(wrappingKey, link, dstKey) {\n    const wrappedKey = JSON.parse(link.data.wrappedKey);\n    // Signatures of keys contain the key itself. This way we only need\n    // to access the KeyLinks to decrypt/verify keys.\n    let nextRawKey;\n    if (wrappedKey.signatures) {\n      nextRawKey = await this.encryptionService.verify(wrappingKey, wrappedKey);\n    } else {\n      nextRawKey = await this.encryptionService.decrypt(\n        wrappingKey,\n        wrappedKey\n      );\n    }\n    dstKey.jwk = await KFS.asKey(nextRawKey);\n    dstKey.task = null;\n  }\n\n  private async _unwrap(key: JWK.Key, path: KeyGraphEdge[]): Promise<JWK.Key> {\n    for (const link of path) {\n      const dstKey = this.key(link.data.keyId);\n      if (dstKey.jwk) {\n        key = dstKey.jwk;\n        continue;\n      }\n\n      if (!dstKey.task) {\n        dstKey.task = this._unwrapLink(key, link, dstKey);\n      }\n\n      await dstKey.task;\n      key = dstKey.jwk;\n    }\n\n    return key;\n  }\n\n  public async unwrapWithPassKey(\n    passKeyId: string,\n    passKey: JWK.Key,\n    keyId: string\n  ): Promise<Key> {\n    // Get path of the directory key.\n    const path = this.getPath(passKeyId, keyId);\n\n    return {\n      id: keyId,\n      jwk: await this._unwrap(passKey, path),\n    };\n  }\n\n  async unwrapKey(masterKeyId: string, keyId: string): Promise<Key> {\n    // The first key should be a masterKey\n    const masterKey = await this.keyService.loadMasterKey(masterKeyId);\n\n    if (masterKeyId === keyId) {\n      return masterKey;\n    }\n\n    // Get path of the directory key.\n    const path = this.getPath(masterKey.id, keyId);\n\n    return {\n      id: keyId,\n      jwk: await this._unwrap(masterKey.jwk, path),\n    };\n  }\n\n  async decryptFromString<T>(\n    keyOrId: string | Key,\n    cipherData: string,\n    options?: DecryptOptions\n  ): Promise<T> {\n    if (cipherData) {\n      const key = await this.getJwkKey(keyOrId);\n      return (await this.encryptionService.decrypt(\n        key,\n        JSON.parse(cipherData),\n        options\n      )) as any;\n    }\n    return null;\n  }\n\n  async decryptFile(keyId: string, file: any): Promise<any> {\n    const key = await this.getJwkKey(keyId);\n    return (await this.encryptionService.decrypt(key, file, {\n      payloadType: 'ArrayBuffer',\n    })) as any;\n  }\n\n  // TODO rename this to encrypt() and use as the most common usecase\n  async encryptToString(\n    key: string | Key | JWK.Key,\n    content: any\n  ): Promise<string> {\n    // Empty string should be encrypted since you want to clear the field.\n    // Null is not encrypted because it's not valid JSON in the old JSON spec. Use\n    // empty string instead. It'll function as a logic false as well.\n    // Note that passing in empty string means it'll be encrypted which verifies\n    // it's integrity. But we still want to have a way to set the DB field\n    // to NULL, so we explicitly return null when content == null. A null\n    // variable in graphql mutation on KC server clears the field to NULL.\n    if (content == null) {\n      return null;\n    }\n\n    const jwk = asJwk(key) || (await this.getJwkKey(key as string | Key));\n    return this.encryptionService.encryptToString(jwk, content);\n  }\n\n  // Wraps a symmetric encryption key.\n  // Throws exception if wrapping public keys.\n  async wrapKey(\n    wrappingKey: string | Key | JWK.Key,\n    key: JWK.Key\n  ): Promise<string> {\n    if (!isSymmetricKey(key)) {\n      throw new KcBadArgumentException(\n        'Only allowing wrapping of symmetric keys.'\n      );\n    }\n\n    return this.encryptToString(wrappingKey, key.toJSON(true));\n  }\n\n  // TODO\n  // async wrapPublicKey<T>();\n  // async wrapPrivateKey<T>();\n\n  async encryptWithNewKey(wrappingKeyId: string, cipherClearJson: JSONObject) {\n    const key = await this.keyFactory.createKey();\n    const wrappedKey = await this.encryptToString(\n      wrappingKeyId,\n      key.toJSON(true)\n    );\n    const cipher = await this.encryptToString(key, cipherClearJson);\n\n    return {\n      key,\n      wrappingKeyId,\n      wrappedKey,\n      cipher,\n    };\n  }\n}\n"]}
@@ -36,7 +36,7 @@ export class KeyService {
36
36
  this.resetKeys();
37
37
  this.persistService.clear();
38
38
  }
39
- populateKeys(keys) {
39
+ setKeys(keys) {
40
40
  this.keys = keys;
41
41
  }
42
42
  get currentPassKey() {
@@ -121,4 +121,4 @@ KeyService.ctorParameters = () => [
121
121
  { type: undefined, decorators: [{ type: Inject, args: [KC_CONFIG,] }] },
122
122
  { type: PersistService }
123
123
  ];
124
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"key.service.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/key/key.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable } from '@angular/core';\nimport { KcConfig, KC_CONFIG } from '../life-ready.config';\nimport { PersistService } from '../persist/persist.service';\nimport { KcNotFoundException } from '../_common/exceptions';\nimport { KeyFactoryService as KFS } from './key-factory.service';\nimport { Key, PassKey } from './key.types';\n\nexport class UserKeys {\n  passKey: PassKey;\n  masterKey: Key;\n  rootKey?: Key;\n  pxk?: Key;\n  sigPxk?: Key;\n}\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class KeyService {\n  private readonly STORE_MASTER_KEY = 'masterKey';\n  // variables\n  private keys: UserKeys;\n  private masterKey: Key;\n\n  // AZ: This can't be change easily. It's basically a PassK or PassIdp rotation.\n  // todo: we should eventually increase this periodically to match with Moore's law.\n  // The iterations for each key are kept by the server as well but we assume the value\n  // from the server is not trustworthy, so need to have minimum thresholds here.\n  // If creating new keys, these minimum are used.\n  public readonly MIN_PASS_IDP_PBKDF_ITER = 100000;\n  public readonly MIN_PASS_KEY_PBKDF_ITER = 100000;\n  public readonly MIN_LBOP_KEY_PBKDF_ITER = 100000;\n\n  // These are used as the default values. They must be larger than the minimum values.\n  public readonly DEFAULT_PASS_IDP_PBKDF_ITER = this.MIN_PASS_IDP_PBKDF_ITER;\n  public readonly DEFAULT_PASS_KEY_PBKDF_ITER = this.MIN_PASS_KEY_PBKDF_ITER;\n  public readonly DEFAULT_LBOP_KEY_PBKDF_ITER = this.MIN_LBOP_KEY_PBKDF_ITER;\n\n  constructor(\n    @Inject(KC_CONFIG) private config: KcConfig,\n    private persistService: PersistService\n  ) {\n    this.resetKeys();\n  }\n\n  resetKeys() {\n    this.keys = null;\n    this.masterKey = null;\n  }\n\n  purgeKeys() {\n    this.resetKeys();\n    this.persistService.clear();\n  }\n\n  populateKeys(keys: UserKeys) {\n    this.keys = keys;\n  }\n\n  public get currentPassKey(): Key {\n    return this.keys.passKey;\n  }\n\n  public get currentMasterKey(): Key {\n    return this.keys.masterKey;\n  }\n\n  public get currentRootKey(): Key {\n    return this.keys.rootKey;\n  }\n\n  public get currentPxk(): Key {\n    return this.keys.pxk;\n  }\n\n  public get currentSigPxk(): Key {\n    return this.keys.sigPxk;\n  }\n\n  private expiresAfter(seconds: number): Date {\n    return new Date(Date.now() + 1000 * seconds);\n  }\n\n  async persistMasterKey(\n    masterKey: Key,\n    expiresAfterSeconds: number\n  ): Promise<void> {\n    const storedKey = {\n      id: masterKey.id,\n      jwk: masterKey.jwk.toJSON(true),\n    };\n\n    this.masterKey = masterKey;\n\n    // Save in an expirable cookie.\n    await this.persistService.set({\n      name: this.STORE_MASTER_KEY,\n      value: storedKey,\n      expiry: this.expiresAfter(expiresAfterSeconds),\n      serverSession: !this.config.disableSessionEncryptionKey,\n    });\n  }\n\n  async setMasterKeyExpiresAfterSeconds(seconds: number): Promise<void> {\n    const storedKey = await this.persistService.get(this.STORE_MASTER_KEY);\n    if (storedKey == null) {\n      throw new KcNotFoundException(\n        `Can not find masterKey in persisted storage using name: ${this.STORE_MASTER_KEY}`\n      );\n    }\n    await this.persistService.set({\n      name: this.STORE_MASTER_KEY,\n      value: storedKey,\n      expiry: this.expiresAfter(seconds),\n      serverSession: !this.config.disableSessionEncryptionKey,\n    });\n  }\n\n  // There's little benefit in using WebCrypto's none-extractable keys because if there\n  // is an XSS attack, then the attacker has control over the js that downloads the keys. The\n  // attacker can modify the code to import the keys as extractable. So none-extractable keys\n  // are only useful if they are already persisted and the user cannot download any more keys,\n  // which is not feasible.\n  // So storing the PassKey in localstorage for now, at least till we know what the usage\n  // pattern is, i.e. how often do we need to use the RootK, MaterK, and PassK.\n  async loadMasterKey(masterKeyId: string): Promise<Key> {\n    if (!this.masterKey) {\n      const storedKey = await this.persistService.get(this.STORE_MASTER_KEY);\n\n      if (!storedKey) {\n        throw new KcNotFoundException(\n          'Could not find masterKey in persisted storage'\n        );\n      }\n\n      if (storedKey.id !== masterKeyId) {\n        throw new KcNotFoundException(\n          `masterKeyId ${storedKey.id} in persisted storage does not match the one requested ${masterKeyId}`\n        );\n      }\n\n      storedKey.jwk = await KFS.asKey(storedKey.jwk);\n\n      this.masterKey = storedKey;\n    }\n\n    return this.masterKey;\n  }\n}\n"]}
124
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"key.service.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/key/key.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable } from '@angular/core';\nimport { KcConfig, KC_CONFIG } from '../life-ready.config';\nimport { PersistService } from '../persist/persist.service';\nimport { KcNotFoundException } from '../_common/exceptions';\nimport { KeyFactoryService as KFS } from './key-factory.service';\nimport { Key, PassKey } from './key.types';\n\nexport class UserKeys {\n  passKey: PassKey;\n  masterKey: Key;\n  rootKey?: Key;\n  pxk?: Key;\n  sigPxk?: Key;\n}\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class KeyService {\n  private readonly STORE_MASTER_KEY = 'masterKey';\n  // variables\n  private keys: UserKeys;\n  private masterKey: Key;\n\n  // AZ: This can't be change easily. It's basically a PassK or PassIdp rotation.\n  // todo: we should eventually increase this periodically to match with Moore's law.\n  // The iterations for each key are kept by the server as well but we assume the value\n  // from the server is not trustworthy, so need to have minimum thresholds here.\n  // If creating new keys, these minimum are used.\n  public readonly MIN_PASS_IDP_PBKDF_ITER = 100000;\n  public readonly MIN_PASS_KEY_PBKDF_ITER = 100000;\n  public readonly MIN_LBOP_KEY_PBKDF_ITER = 100000;\n\n  // These are used as the default values. They must be larger than the minimum values.\n  public readonly DEFAULT_PASS_IDP_PBKDF_ITER = this.MIN_PASS_IDP_PBKDF_ITER;\n  public readonly DEFAULT_PASS_KEY_PBKDF_ITER = this.MIN_PASS_KEY_PBKDF_ITER;\n  public readonly DEFAULT_LBOP_KEY_PBKDF_ITER = this.MIN_LBOP_KEY_PBKDF_ITER;\n\n  constructor(\n    @Inject(KC_CONFIG) private config: KcConfig,\n    private persistService: PersistService\n  ) {\n    this.resetKeys();\n  }\n\n  resetKeys() {\n    this.keys = null;\n    this.masterKey = null;\n  }\n\n  purgeKeys() {\n    this.resetKeys();\n    this.persistService.clear();\n  }\n\n  setKeys(keys: UserKeys) {\n    this.keys = keys;\n  }\n\n  public get currentPassKey(): Key {\n    return this.keys.passKey;\n  }\n\n  public get currentMasterKey(): Key {\n    return this.keys.masterKey;\n  }\n\n  public get currentRootKey(): Key {\n    return this.keys.rootKey;\n  }\n\n  public get currentPxk(): Key {\n    return this.keys.pxk;\n  }\n\n  public get currentSigPxk(): Key {\n    return this.keys.sigPxk;\n  }\n\n  private expiresAfter(seconds: number): Date {\n    return new Date(Date.now() + 1000 * seconds);\n  }\n\n  async persistMasterKey(\n    masterKey: Key,\n    expiresAfterSeconds: number\n  ): Promise<void> {\n    const storedKey = {\n      id: masterKey.id,\n      jwk: masterKey.jwk.toJSON(true),\n    };\n\n    this.masterKey = masterKey;\n\n    // Save in an expirable cookie.\n    await this.persistService.set({\n      name: this.STORE_MASTER_KEY,\n      value: storedKey,\n      expiry: this.expiresAfter(expiresAfterSeconds),\n      serverSession: !this.config.disableSessionEncryptionKey,\n    });\n  }\n\n  async setMasterKeyExpiresAfterSeconds(seconds: number): Promise<void> {\n    const storedKey = await this.persistService.get(this.STORE_MASTER_KEY);\n    if (storedKey == null) {\n      throw new KcNotFoundException(\n        `Can not find masterKey in persisted storage using name: ${this.STORE_MASTER_KEY}`\n      );\n    }\n    await this.persistService.set({\n      name: this.STORE_MASTER_KEY,\n      value: storedKey,\n      expiry: this.expiresAfter(seconds),\n      serverSession: !this.config.disableSessionEncryptionKey,\n    });\n  }\n\n  // There's little benefit in using WebCrypto's none-extractable keys because if there\n  // is an XSS attack, then the attacker has control over the js that downloads the keys. The\n  // attacker can modify the code to import the keys as extractable. So none-extractable keys\n  // are only useful if they are already persisted and the user cannot download any more keys,\n  // which is not feasible.\n  // So storing the PassKey in localstorage for now, at least till we know what the usage\n  // pattern is, i.e. how often do we need to use the RootK, MaterK, and PassK.\n  async loadMasterKey(masterKeyId: string): Promise<Key> {\n    if (!this.masterKey) {\n      const storedKey = await this.persistService.get(this.STORE_MASTER_KEY);\n\n      if (!storedKey) {\n        throw new KcNotFoundException(\n          'Could not find masterKey in persisted storage'\n        );\n      }\n\n      if (storedKey.id !== masterKeyId) {\n        throw new KcNotFoundException(\n          `masterKeyId ${storedKey.id} in persisted storage does not match the one requested ${masterKeyId}`\n        );\n      }\n\n      storedKey.jwk = await KFS.asKey(storedKey.jwk);\n\n      this.masterKey = storedKey;\n    }\n\n    return this.masterKey;\n  }\n}\n"]}
@@ -1117,7 +1117,7 @@ class KeyService {
1117
1117
  this.resetKeys();
1118
1118
  this.persistService.clear();
1119
1119
  }
1120
- populateKeys(keys) {
1120
+ setKeys(keys) {
1121
1121
  this.keys = keys;
1122
1122
  }
1123
1123
  get currentPassKey() {
@@ -1230,7 +1230,7 @@ class KeyGraphService {
1230
1230
  }
1231
1231
  populateKeys(userKey) {
1232
1232
  return __awaiter(this, void 0, void 0, function* () {
1233
- this.keyService.populateKeys({
1233
+ this.keyService.setKeys({
1234
1234
  passKey: userKey.passKey,
1235
1235
  masterKey: yield this.keyService.loadMasterKey(userKey.masterKey.id),
1236
1236
  rootKey: yield this.unwrapKey(userKey.masterKey.id, userKey.rootKey.id),
@@ -5869,7 +5869,7 @@ class LifeReadyAuthService {
5869
5869
  const passKey = (yield this.keyFactory.derivePassKey(Object.assign({ password }, resetUser.passKey.passKeyParams))).jwk;
5870
5870
  yield this.idleService.persistMasterKey(yield this.keyGraphService.unwrapWithPassKey(resetUser.passKey.id, passKey, resetUser.masterKey.id));
5871
5871
  }
5872
- this.keyService.populateKeys({
5872
+ this.keyService.setKeys({
5873
5873
  passKey: {
5874
5874
  id: resetUser.passKey.id,
5875
5875
  },
@@ -6301,7 +6301,7 @@ let Auth2Service = Auth2Service_1 = class Auth2Service extends LrService {
6301
6301
  fetchResetUser() {
6302
6302
  return __awaiter(this, void 0, void 0, function* () {
6303
6303
  return (yield this.api.query({
6304
- query: CurrentUserQuery$1,
6304
+ query: ResetUserQuery,
6305
6305
  processorOptions: {
6306
6306
  hasKeys: false,
6307
6307
  },
@@ -6484,7 +6484,6 @@ let Auth2Service = Auth2Service_1 = class Auth2Service extends LrService {
6484
6484
  const passKey = (yield this.keyFactoryService.derivePassKey(Object.assign({ password }, userKeys.passKey.passKeyParams))).jwk;
6485
6485
  yield this.idleService.persistMasterKey(yield this.keyGraphService.unwrapWithPassKey(userKeys.passKey.id, passKey, userKeys.masterKey.id));
6486
6486
  }
6487
- yield this.keyGraphService.populateKeys(userKeys);
6488
6487
  });
6489
6488
  }
6490
6489
  loadUser(cognitoUser, password) {
@@ -6507,6 +6506,8 @@ let Auth2Service = Auth2Service_1 = class Auth2Service extends LrService {
6507
6506
  password,
6508
6507
  sessionEncryptionKey: currentUser.sessionEncryptionKey,
6509
6508
  });
6509
+ // Regular user populates all keys
6510
+ yield this.keyGraphService.populateKeys(currentUser.currentUserKey);
6510
6511
  const { username } = currentUser;
6511
6512
  const userAttributes = yield this.cognito.userAttributes(cognitoUser);
6512
6513
  return {
@@ -6520,18 +6521,22 @@ let Auth2Service = Auth2Service_1 = class Auth2Service extends LrService {
6520
6521
  loadResetUser(cognitoUser, password) {
6521
6522
  return __awaiter(this, void 0, void 0, function* () {
6522
6523
  const resetUser = yield this.fetchResetUser();
6523
- this.loadUserKeys({
6524
- userKeys: {
6525
- passKey: {
6526
- id: resetUser.passKey.id,
6527
- },
6528
- masterKey: {
6529
- id: resetUser.masterKey.id,
6530
- },
6524
+ const userKeys = {
6525
+ passKey: {
6526
+ id: resetUser.passKey.id,
6527
+ passKeyParams: resetUser.passKey.passKeyParams,
6531
6528
  },
6529
+ masterKey: {
6530
+ id: resetUser.masterKey.id,
6531
+ },
6532
+ };
6533
+ yield this.loadUserKeys({
6534
+ userKeys,
6532
6535
  password,
6533
6536
  sessionEncryptionKey: resetUser.sessionEncryptionKey,
6534
6537
  });
6538
+ // Reset user only sets a subset of keys
6539
+ yield this.keyService.setKeys(userKeys);
6535
6540
  const { username } = resetUser;
6536
6541
  const userAttributes = yield this.cognito.userAttributes(cognitoUser);
6537
6542
  return {