@lifeready/core 9.0.2 → 9.0.7
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 +201 -177
- 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/api/types/lr-graphql.types.js +4 -1
- package/esm2015/lib/key-exchange/key-exchange.service.js +17 -1
- package/esm2015/lib/register/register.service.js +3 -3
- package/fesm2015/lifeready-core.js +20 -1
- package/fesm2015/lifeready-core.js.map +1 -1
- package/package.json +1 -1
|
@@ -4,7 +4,7 @@ import { Inject, Injectable } from '@angular/core';
|
|
|
4
4
|
import { AuthClass } from '@aws-amplify/auth/lib-esm/Auth';
|
|
5
5
|
import { EncryptionService } from '../encryption/encryption.service';
|
|
6
6
|
import { KeyFactoryService } from '../key/key-factory.service';
|
|
7
|
-
import { KC_CONFIG } from '../life-ready.config';
|
|
7
|
+
import { KC_CONFIG, httpOptions } from '../life-ready.config';
|
|
8
8
|
import { PasswordService } from '../password/password.service';
|
|
9
9
|
import * as i0 from "@angular/core";
|
|
10
10
|
import * as i1 from "../life-ready.config";
|
|
@@ -141,7 +141,7 @@ export class RegisterService {
|
|
|
141
141
|
// The account is just the email
|
|
142
142
|
try {
|
|
143
143
|
const response = yield this.http
|
|
144
|
-
.get(`${this.config.authUrl}users/hibp/breachedaccount/${account}/?truncateResponse=false
|
|
144
|
+
.get(`${this.config.authUrl}users/hibp/breachedaccount/${account}/?truncateResponse=false`, yield httpOptions(this.auth, this.config))
|
|
145
145
|
.toPromise();
|
|
146
146
|
return response;
|
|
147
147
|
}
|
|
@@ -170,4 +170,4 @@ RegisterService.ctorParameters = () => [
|
|
|
170
170
|
{ type: EncryptionService },
|
|
171
171
|
{ type: PasswordService }
|
|
172
172
|
];
|
|
173
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"register.service.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/register/register.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\nimport { Inject, Injectable } from '@angular/core';\nimport { AuthClass } from '@aws-amplify/auth/lib-esm/Auth';\nimport { JSONObject } from '../api/types';\nimport { EncryptionService } from '../encryption/encryption.service';\nimport { KeyFactoryService } from '../key/key-factory.service';\nimport { KcConfig, KC_CONFIG } from '../life-ready.config';\nimport { PasswordService } from '../password/password.service';\nimport { RegisterResult } from './register.types';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class RegisterService {\n  constructor(\n    @Inject(KC_CONFIG) private config: KcConfig,\n    private auth: AuthClass,\n    private http: HttpClient,\n    private keyFactory: KeyFactoryService,\n    private encryptionService: EncryptionService,\n    private passwordService: PasswordService\n  ) {}\n\n  /**\n   * Request a verification code to be sent out to an email.\n   * @return Info needed to be submitted along with the verification code\n   */\n  public async verifyEmail(email: string): Promise<string> {\n    const { claim_id } = await this.http\n      .post<{ claim_id }>(`${this.config.authUrl}cove/claim/email/`, {\n        address: email,\n        context: 'signup',\n      })\n      .toPromise();\n    return claim_id;\n  }\n\n  public async verifyPhone(phoneNumber: string): Promise<string> {\n    const { claim_id } = await this.http\n      .post<{ claim_id }>(`${this.config.authUrl}cove/claim/sms/`, {\n        address: phoneNumber,\n        context: 'signup',\n      })\n      .toPromise();\n    return claim_id;\n  }\n\n  public async confirmVerificationCode(\n    verificationId: string,\n    verificationCode: string\n  ): Promise<string> {\n    const { token } = await this.http\n      .post<{ token }>(`${this.config.authUrl}cove/respond/`, {\n        claim_id: verificationId,\n        v_code: verificationCode,\n      })\n      .toPromise();\n    return token;\n  }\n\n  public async register(\n    email: string,\n    password: CryptoKey,\n    verificationId: string,\n    verificationToken: string,\n    verificationType: 'email' | 'phone' = 'email'\n  ): Promise<RegisterResult> {\n    // Generate the key material needed for PassIdp which will be the password used for Cognito.\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    const rootKey = await this.keyFactory.createKey();\n    const wrappedRootKey = await this.encryptionService.encrypt(\n      masterKey,\n      rootKey.toJSON(true)\n    );\n\n    // Encryption PKC key\n    const prk = await this.keyFactory.createPkcKey();\n    const wrappedPrk = await this.encryptionService.encrypt(\n      rootKey,\n      prk.toJSON(true)\n    );\n\n    // Signing PKC key\n    const sigPrk = await this.keyFactory.createPkcSignKey();\n    const wrappedSigPrk = await this.encryptionService.encrypt(\n      rootKey,\n      sigPrk.toJSON(true)\n    );\n\n    // API call to setup profile\n    const user = await this.http\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n      .post<any>(`${this.config.authUrl}users/`, {\n        claims: [\n          {\n            type: verificationType,\n            token: verificationToken,\n            claim_id: verificationId,\n          },\n        ],\n        pass_idp_params: passKeyBundle.passIdpParams,\n        pass_idp_verifier_pbk: passKeyBundle.passIdpVerifier.toJSON(),\n        wrapped_pass_idp_verifier_prk: passKeyBundle.wrappedPassIdpVerifierPrk,\n        pass_key_params: passKeyBundle.passKeyParams,\n        wrapped_master_key: wrappedMasterKey,\n        wrapped_root_key: wrappedRootKey,\n        pbk: prk.toJSON(), // public encryption key\n        wrapped_prk: wrappedPrk,\n        sig_pbk: sigPrk.toJSON(), // public signing key\n        wrapped_sig_prk: wrappedSigPrk,\n      })\n      .toPromise();\n\n    // API call to create user on cognito\n    const attributes = {};\n    user.claims.forEach((claim) => {\n      attributes[claim.type] = claim.value;\n    });\n\n    // Random suffix for uniqueness. If there's a duplicate, then used just needs to\n    // sign up again. But chances of collision is low.\n    const suffix = this.keyFactory.randomDigitsNoZeros(4);\n\n    const cognitoUser = await this.auth.signUp({\n      username: `${email.split('@')[0]}.${suffix}`,\n      password: this.passwordService.getPassIdpString(passKeyBundle.passIdp),\n      attributes,\n      // Unfortunately, validationData is not passed to the post\n      // confirmation cognito trigger. So can can't do the association there.\n      // The current workflow will create a new user on LR before signing up\n      // with Cognito. Then Cognito can use the user.id and user.pre_sign_up_token to\n      // do the validation of the attributes.\n      // validationData: [\n      //   new CognitoUserAttribute({\n      //     Name: \"user_id\",\n      //     Value: String(user.id)\n      //   }),\n      //   new CognitoUserAttribute({\n      //     Name: \"user_pre_sign_up_token\",\n      //     Value: user.pre_sign_up_token\n      //   })\n      // ]\n      clientMetadata: {\n        user_id: String(user.id),\n        user_pre_sign_up_token: String(user.pre_sign_up_token),\n      },\n    });\n\n    return {\n      username: cognitoUser.user.getUsername(),\n      userId: user.id,\n      preSignUpToken: user.pre_sign_up_token,\n      userSub: cognitoUser.userSub,\n    };\n  }\n\n  public async hibpBreachedAccounts(account: string) {\n    // The account is just the email\n    try {\n      const response = await this.http\n        .get<JSONObject>(\n          `${this.config.authUrl}users/hibp/breachedaccount/${account}/?truncateResponse=false`\n        )\n        .toPromise();\n      return response;\n    } catch (error) {\n      if (error.status === 404) {\n        return null;\n      } else {\n        throw error;\n      }\n    }\n  }\n}\n"]}
|
|
173
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"register.service.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/register/register.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\nimport { Inject, Injectable } from '@angular/core';\nimport { AuthClass } from '@aws-amplify/auth/lib-esm/Auth';\nimport { JSONObject } from '../api/types';\nimport { EncryptionService } from '../encryption/encryption.service';\nimport { KeyFactoryService } from '../key/key-factory.service';\nimport { KcConfig, KC_CONFIG, httpOptions } from '../life-ready.config';\nimport { PasswordService } from '../password/password.service';\nimport { RegisterResult } from './register.types';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class RegisterService {\n  constructor(\n    @Inject(KC_CONFIG) private config: KcConfig,\n    private auth: AuthClass,\n    private http: HttpClient,\n    private keyFactory: KeyFactoryService,\n    private encryptionService: EncryptionService,\n    private passwordService: PasswordService\n  ) {}\n\n  /**\n   * Request a verification code to be sent out to an email.\n   * @return Info needed to be submitted along with the verification code\n   */\n  public async verifyEmail(email: string): Promise<string> {\n    const { claim_id } = await this.http\n      .post<{ claim_id }>(`${this.config.authUrl}cove/claim/email/`, {\n        address: email,\n        context: 'signup',\n      })\n      .toPromise();\n    return claim_id;\n  }\n\n  public async verifyPhone(phoneNumber: string): Promise<string> {\n    const { claim_id } = await this.http\n      .post<{ claim_id }>(`${this.config.authUrl}cove/claim/sms/`, {\n        address: phoneNumber,\n        context: 'signup',\n      })\n      .toPromise();\n    return claim_id;\n  }\n\n  public async confirmVerificationCode(\n    verificationId: string,\n    verificationCode: string\n  ): Promise<string> {\n    const { token } = await this.http\n      .post<{ token }>(`${this.config.authUrl}cove/respond/`, {\n        claim_id: verificationId,\n        v_code: verificationCode,\n      })\n      .toPromise();\n    return token;\n  }\n\n  public async register(\n    email: string,\n    password: CryptoKey,\n    verificationId: string,\n    verificationToken: string,\n    verificationType: 'email' | 'phone' = 'email'\n  ): Promise<RegisterResult> {\n    // Generate the key material needed for PassIdp which will be the password used for Cognito.\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    const rootKey = await this.keyFactory.createKey();\n    const wrappedRootKey = await this.encryptionService.encrypt(\n      masterKey,\n      rootKey.toJSON(true)\n    );\n\n    // Encryption PKC key\n    const prk = await this.keyFactory.createPkcKey();\n    const wrappedPrk = await this.encryptionService.encrypt(\n      rootKey,\n      prk.toJSON(true)\n    );\n\n    // Signing PKC key\n    const sigPrk = await this.keyFactory.createPkcSignKey();\n    const wrappedSigPrk = await this.encryptionService.encrypt(\n      rootKey,\n      sigPrk.toJSON(true)\n    );\n\n    // API call to setup profile\n    const user = await this.http\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n      .post<any>(`${this.config.authUrl}users/`, {\n        claims: [\n          {\n            type: verificationType,\n            token: verificationToken,\n            claim_id: verificationId,\n          },\n        ],\n        pass_idp_params: passKeyBundle.passIdpParams,\n        pass_idp_verifier_pbk: passKeyBundle.passIdpVerifier.toJSON(),\n        wrapped_pass_idp_verifier_prk: passKeyBundle.wrappedPassIdpVerifierPrk,\n        pass_key_params: passKeyBundle.passKeyParams,\n        wrapped_master_key: wrappedMasterKey,\n        wrapped_root_key: wrappedRootKey,\n        pbk: prk.toJSON(), // public encryption key\n        wrapped_prk: wrappedPrk,\n        sig_pbk: sigPrk.toJSON(), // public signing key\n        wrapped_sig_prk: wrappedSigPrk,\n      })\n      .toPromise();\n\n    // API call to create user on cognito\n    const attributes = {};\n    user.claims.forEach((claim) => {\n      attributes[claim.type] = claim.value;\n    });\n\n    // Random suffix for uniqueness. If there's a duplicate, then used just needs to\n    // sign up again. But chances of collision is low.\n    const suffix = this.keyFactory.randomDigitsNoZeros(4);\n\n    const cognitoUser = await this.auth.signUp({\n      username: `${email.split('@')[0]}.${suffix}`,\n      password: this.passwordService.getPassIdpString(passKeyBundle.passIdp),\n      attributes,\n      // Unfortunately, validationData is not passed to the post\n      // confirmation cognito trigger. So can can't do the association there.\n      // The current workflow will create a new user on LR before signing up\n      // with Cognito. Then Cognito can use the user.id and user.pre_sign_up_token to\n      // do the validation of the attributes.\n      // validationData: [\n      //   new CognitoUserAttribute({\n      //     Name: \"user_id\",\n      //     Value: String(user.id)\n      //   }),\n      //   new CognitoUserAttribute({\n      //     Name: \"user_pre_sign_up_token\",\n      //     Value: user.pre_sign_up_token\n      //   })\n      // ]\n      clientMetadata: {\n        user_id: String(user.id),\n        user_pre_sign_up_token: String(user.pre_sign_up_token),\n      },\n    });\n\n    return {\n      username: cognitoUser.user.getUsername(),\n      userId: user.id,\n      preSignUpToken: user.pre_sign_up_token,\n      userSub: cognitoUser.userSub,\n    };\n  }\n\n  public async hibpBreachedAccounts(account: string) {\n    // The account is just the email\n    try {\n      const response = await this.http\n        .get<JSONObject>(\n          `${this.config.authUrl}users/hibp/breachedaccount/${account}/?truncateResponse=false`,\n          await httpOptions(this.auth, this.config)\n        )\n        .toPromise();\n      return response;\n    } catch (error) {\n      if (error.status === 404) {\n        return null;\n      } else {\n        throw error;\n      }\n    }\n  }\n}\n"]}
|
|
@@ -2909,8 +2909,11 @@ var ScenarioLastClaimState;
|
|
|
2909
2909
|
})(ScenarioLastClaimState || (ScenarioLastClaimState = {}));
|
|
2910
2910
|
var LinkTypeField;
|
|
2911
2911
|
(function (LinkTypeField) {
|
|
2912
|
+
// HARD links will persist the child as long as the parent exists
|
|
2912
2913
|
LinkTypeField["HARD"] = "HARD";
|
|
2914
|
+
// SOFT links will provides permission inheritance but will not persist the child if the parent is deleted
|
|
2913
2915
|
LinkTypeField["SOFT"] = "SOFT";
|
|
2916
|
+
// REFERENCE links do not provide permission inheritance and will not persist the child if the parent is deleted
|
|
2914
2917
|
LinkTypeField["REFERENCE"] = "REFERENCE";
|
|
2915
2918
|
})(LinkTypeField || (LinkTypeField = {}));
|
|
2916
2919
|
var BillingPeriodField;
|
|
@@ -6794,6 +6797,14 @@ let KeyExchangeService = class KeyExchangeService extends LrService {
|
|
|
6794
6797
|
if (otKey && otk.otKeyCipher) {
|
|
6795
6798
|
otk = Object.assign(Object.assign({}, otk), { otKey, otKeyCipherClearJson: yield this.encryptionService.decrypt(otKey, keyExchange.otk.otKeyCipher) });
|
|
6796
6799
|
}
|
|
6800
|
+
else if (otk.otKeyCipher && !otKey) {
|
|
6801
|
+
// Log a warning when we have cipher data but couldn't obtain the key to decrypt it.
|
|
6802
|
+
// This typically happens when:
|
|
6803
|
+
// - The otKeyK (raw one-time key from URL hash) was not provided or was empty
|
|
6804
|
+
// - The responder doesn't have a responderPbkCipher (new user via invite)
|
|
6805
|
+
console.warn('KeyExchangeService: Unable to decrypt OTK cipher - one-time key not available. ' +
|
|
6806
|
+
'otKeyK provided:', !!otKeyK, 'otKeyK value:', otKeyK ? '[present]' : '[empty/missing]');
|
|
6807
|
+
}
|
|
6797
6808
|
return Object.assign(Object.assign({}, keyExchange), { otk });
|
|
6798
6809
|
});
|
|
6799
6810
|
}
|
|
@@ -7000,7 +7011,15 @@ let KeyExchangeService = class KeyExchangeService extends LrService {
|
|
|
7000
7011
|
return this.mutate(this.respondOtkMutation(input));
|
|
7001
7012
|
}
|
|
7002
7013
|
respondOtkMutation({ keyExchangeId, token, decryptedOtk, message, initiatorContactCard, responderContactCard, }) {
|
|
7014
|
+
var _a;
|
|
7003
7015
|
return __awaiter(this, void 0, void 0, function* () {
|
|
7016
|
+
// Validate that the OTK was properly decrypted before proceeding.
|
|
7017
|
+
// This can fail if the one-time key (otKeyK) was not provided or was invalid,
|
|
7018
|
+
// which can happen if the invite URL hash fragment was lost (e.g., page refresh after hash removal).
|
|
7019
|
+
if (!((_a = decryptedOtk === null || decryptedOtk === void 0 ? void 0 : decryptedOtk.otKeyCipherClearJson) === null || _a === void 0 ? void 0 : _a.initiator)) {
|
|
7020
|
+
throw new Error('Failed to decrypt key exchange data. The invite link may be invalid or expired. ' +
|
|
7021
|
+
'Please request a new invite from the sender.');
|
|
7022
|
+
}
|
|
7004
7023
|
const rootKey = this.keyService.currentRootKey;
|
|
7005
7024
|
const masterKey = this.keyService.currentMasterKey;
|
|
7006
7025
|
const sharedKey = yield this.keyFactory.createKey();
|
|
@@ -8384,7 +8403,7 @@ class RegisterService {
|
|
|
8384
8403
|
// The account is just the email
|
|
8385
8404
|
try {
|
|
8386
8405
|
const response = yield this.http
|
|
8387
|
-
.get(`${this.config.authUrl}users/hibp/breachedaccount/${account}/?truncateResponse=false
|
|
8406
|
+
.get(`${this.config.authUrl}users/hibp/breachedaccount/${account}/?truncateResponse=false`, yield httpOptions(this.auth, this.config))
|
|
8388
8407
|
.toPromise();
|
|
8389
8408
|
return response;
|
|
8390
8409
|
}
|