@lifeready/core 1.0.0 → 1.0.2

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.
@@ -1,21 +1,15 @@
1
1
  import { __awaiter, __decorate } from "tslib";
2
- import { Hub } from '@aws-amplify/core';
3
2
  import { Inject, Injectable, Injector, NgZone } from '@angular/core';
4
3
  import { EncryptionService } from '../cryptography/encryption.service';
5
4
  import { KeyGraphService } from '../cryptography/key-graph.service';
6
5
  import { LR_CONFIG } from '../life-ready.config';
7
6
  import * as slip from '../cryptography/slip39.service';
8
- import { JWK } from 'node-jose';
9
- import { LrBadStateException, LrException } from '../_common/exceptions';
10
- import { CompleteTpPasswordResetRequestMutation, CreateTpAssemblyKeyChallengeMutation, PreCompleteTpPasswordResetRequestMutation, } from './tp-password-reset.gql';
11
7
  import { PasswordService } from '../auth/password.service';
12
8
  import { HttpClient } from '@angular/common/http';
13
9
  import { AuthClass } from '@aws-amplify/auth/lib-esm/Auth';
14
- import { TpPasswordResetService, } from './tp-password-reset.service';
15
10
  import { LifeReadyAuthService } from '../auth/life-ready-auth.service';
16
11
  import { KeyFactoryService } from '../cryptography/key-factory.service';
17
- import { TpClaimState } from '../api/types';
18
- import { LrMutation, LrService } from '../api/lr-graphql';
12
+ import { LrService } from '../api/lr-graphql';
19
13
  import { RunOutsideAngular } from '../_common/run-outside-angular';
20
14
  import * as i0 from "@angular/core";
21
15
  import * as i1 from "../life-ready.config";
@@ -41,7 +35,6 @@ let TpPasswordResetUserService = class TpPasswordResetUserService extends LrServ
41
35
  this.http = http;
42
36
  this.auth = auth;
43
37
  this.lrAuth = lrAuth;
44
- this.CLIENT_NONCE_LENGTH = 32;
45
38
  }
46
39
  verifyEmailContact(email) {
47
40
  return __awaiter(this, void 0, void 0, function* () {
@@ -107,136 +100,6 @@ let TpPasswordResetUserService = class TpPasswordResetUserService extends LrServ
107
100
  };
108
101
  });
109
102
  }
110
- getResetUser(reload = false) {
111
- return __awaiter(this, void 0, void 0, function* () {
112
- if (!reload && this.resetUser) {
113
- return this.resetUser;
114
- }
115
- this.resetUser = yield this.lrAuth.loadResetUser();
116
- return this.resetUser;
117
- });
118
- }
119
- recoverAssemblyKey(resetUser) {
120
- return __awaiter(this, void 0, void 0, function* () {
121
- // Recover the assembly key.
122
- let assemblyKeyParams;
123
- const prk = yield this.keyGraphService.getKey(resetUser.pxk.id);
124
- const shares = yield Promise.all(resetUser.approvals.map((approval) => __awaiter(this, void 0, void 0, function* () {
125
- const partialAssemblyKey = yield this.encryptionService.decrypt(prk, approval.receiverCipherPartialAssemblyKey);
126
- if (assemblyKeyParams) {
127
- if (JSON.stringify(assemblyKeyParams) !==
128
- JSON.stringify(partialAssemblyKey.assemblyKeyParams)) {
129
- throw new LrBadStateException('The assembly key parameters are different between the approvals.');
130
- }
131
- }
132
- else {
133
- assemblyKeyParams = partialAssemblyKey.assemblyKeyParams;
134
- }
135
- return partialAssemblyKey.slip39.share.mnemonics;
136
- })));
137
- console.log('recoverAssemblyKey()', shares);
138
- const rawAssemblyKey = yield this.slip39Service.recoverSecret(shares, TpPasswordResetService.SLIP39_PASSPHRASE);
139
- return JWK.asKey(Object.assign(Object.assign({}, assemblyKeyParams), { k: rawAssemblyKey }));
140
- });
141
- }
142
- completeRequest(newPassword) {
143
- return __awaiter(this, void 0, void 0, function* () {
144
- const resetUser = yield this.getResetUser(true);
145
- if (resetUser.state !== TpClaimState.APPROVED) {
146
- throw new LrBadStateException('Password reset request has not been approved.');
147
- }
148
- // --------------------------------------------------------------
149
- // Prepare all materials to ensure there are no errors.
150
- // --------------------------------------------------------------
151
- const assemblyKey = yield this.recoverAssemblyKey(resetUser);
152
- const { rootKey } = yield this.encryptionService.decrypt(assemblyKey, resetUser.assemblyCipherData);
153
- console.log(rootKey);
154
- // Making sure it's a valid key.
155
- const rootKeyJwk = yield JWK.asKey(rootKey);
156
- const masterKey = yield this.keyGraphService.getKey(resetUser.masterKey.id);
157
- const masterKeyWrappedRootKey = yield this.encryptionService.encryptToString(masterKey.jwk, rootKeyJwk.toJSON(true));
158
- // The new password
159
- const newPassIdpResult = yield this.keyFactory.derivePassIdp(Object.assign({ password: newPassword }, resetUser.passKey.passIdpParams));
160
- const newIdpPassword = this.passwordService.getPassIdpString(newPassIdpResult.jwk);
161
- // --------------------------------------------------------------
162
- // Get assembly key challenge
163
- // --------------------------------------------------------------
164
- const challenge = (yield this.mutate(new LrMutation({
165
- mutation: CreateTpAssemblyKeyChallengeMutation,
166
- variables: {
167
- input: {},
168
- },
169
- }), {
170
- includeKeyGraph: false,
171
- })).createTpAssemblyKeyChallenge.challenge;
172
- console.log(challenge);
173
- // Sign the challenge
174
- // Generate a client side nonce that's no in the server's control.
175
- challenge.clientNonce = this.keyFactory.randomString(this.CLIENT_NONCE_LENGTH);
176
- console.log(challenge);
177
- const assemblyKeyVerifierPrk = yield this.encryptionService.decrypt(assemblyKey, resetUser.wrappedAssemblyKeyVerifierPrk);
178
- const signedChallenge = yield this.encryptionService.sign(assemblyKeyVerifierPrk, challenge);
179
- // --------------------------------------------------------------
180
- // Change password for the original user
181
- // --------------------------------------------------------------
182
- const tempIdpPassword = (yield this.mutate(new LrMutation({
183
- mutation: PreCompleteTpPasswordResetRequestMutation,
184
- variables: {
185
- input: {
186
- signedChallenge: JSON.stringify(signedChallenge),
187
- },
188
- },
189
- }), {
190
- includeKeyGraph: false,
191
- })).preCompleteTpPasswordResetRequest.idpPassword;
192
- // --------------------------------------------------------------
193
- // Login as the original user using new temporary password
194
- // --------------------------------------------------------------
195
- // At this point, the original account's password has been changed
196
- // to a temporary password. It is no longer possible for the user
197
- // to use the original password to login. Any successful login
198
- // can only be using the temporary password. So it's safe to assume
199
- // that we want to "complete" the password reset.
200
- // The maybe 2FA so we listen for the auth event from Amplify.
201
- const retPromise = new Promise((resolve) => {
202
- const listener = (data) => __awaiter(this, void 0, void 0, function* () {
203
- if (data.payload.event !== 'signIn') {
204
- return;
205
- }
206
- Hub.remove('auth', listener);
207
- console.log(data.payload);
208
- yield this.auth.signIn(resetUser.username, newIdpPassword);
209
- // Switch over to the new set of keys
210
- yield this.mutate(new LrMutation({
211
- mutation: CompleteTpPasswordResetRequestMutation,
212
- variables: {
213
- input: {
214
- masterKeyWrappedRootKey,
215
- masterKeyId: masterKey.id,
216
- },
217
- },
218
- }));
219
- resolve();
220
- });
221
- Hub.listen('auth', listener);
222
- });
223
- // Signin as the original user. Password has been reset to temporary one. It should return
224
- // with NEW_PASSWORD_REQUIRED
225
- let user = yield this.auth.signIn(resetUser.username, tempIdpPassword, {
226
- noProxy: 'true',
227
- });
228
- if (user.challengeName !== 'NEW_PASSWORD_REQUIRED') {
229
- throw new LrException({
230
- message: 'Internal error. Expecting Cognito to have done a password reset after call to PreCompleteTpPasswordResetRequestMutation.',
231
- });
232
- }
233
- // Set new password on Idp
234
- // the awsFetch() function passes NEW_PASSWORD_REQUIRED directly to AWS without
235
- // going through the proxy.
236
- user = yield this.auth.completeNewPassword(user, newIdpPassword, {});
237
- return retPromise;
238
- });
239
- }
240
103
  };
241
104
  TpPasswordResetUserService.ɵprov = i0.ɵɵdefineInjectable({ factory: function TpPasswordResetUserService_Factory() { return new TpPasswordResetUserService(i0.ɵɵinject(i0.NgZone), i0.ɵɵinject(i0.INJECTOR), i0.ɵɵinject(i1.LR_CONFIG), i0.ɵɵinject(i2.KeyFactoryService), i0.ɵɵinject(i3.EncryptionService), i0.ɵɵinject(i4.KeyGraphService), i0.ɵɵinject(i5.Slip39Service), i0.ɵɵinject(i6.PasswordService), i0.ɵɵinject(i7.HttpClient), i0.ɵɵinject(i8.AuthClass), i0.ɵɵinject(i9.LifeReadyAuthService)); }, token: TpPasswordResetUserService, providedIn: "root" });
242
105
  TpPasswordResetUserService.decorators = [
@@ -263,4 +126,4 @@ TpPasswordResetUserService = __decorate([
263
126
  })
264
127
  ], TpPasswordResetUserService);
265
128
  export { TpPasswordResetUserService };
266
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tp-password-reset-user.service.js","sourceRoot":"/opt/atlassian/pipelines/agent/build/projects/core/src/","sources":["lib/trusted-parties/tp-password-reset-user.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Hub } from '@aws-amplify/core';\nimport { Inject, Injectable, Injector, NgZone } from '@angular/core';\nimport { EncryptionService } from '../cryptography/encryption.service';\nimport { KeyGraphService } from '../cryptography/key-graph.service';\nimport { LifeReadyConfig, LR_CONFIG } from '../life-ready.config';\nimport * as slip from '../cryptography/slip39.service';\nimport { JWK } from 'node-jose';\nimport { LrBadStateException, LrException } from '../_common/exceptions';\nimport {\n  CompleteTpPasswordResetRequestMutation,\n  CreateTpAssemblyKeyChallengeMutation,\n  PreCompleteTpPasswordResetRequestMutation,\n} from './tp-password-reset.gql';\nimport { PasswordService } from '../auth/password.service';\nimport { HttpClient } from '@angular/common/http';\nimport { AuthClass } from '@aws-amplify/auth/lib-esm/Auth';\nimport {\n  RequestResetResult,\n  TpPasswordResetService,\n} from './tp-password-reset.service';\nimport { ISignUpResult } from 'amazon-cognito-identity-js';\nimport { LifeReadyAuthService } from '../auth/life-ready-auth.service';\nimport { KeyFactoryService } from '../cryptography/key-factory.service';\nimport { TpClaimState, TpPasswordResetUserNode } from '../api/types';\nimport { LrMutation, LrService } from '../api/lr-graphql';\nimport { RunOutsideAngular } from '../_common/run-outside-angular';\n\n@RunOutsideAngular({\n  ngZoneName: 'ngZone',\n})\n@Injectable({\n  providedIn: 'root',\n})\nexport class TpPasswordResetUserService extends LrService {\n  private readonly CLIENT_NONCE_LENGTH = 32;\n  private resetUser: TpPasswordResetUserNode;\n\n  constructor(\n    private ngZone: NgZone,\n    private injector: Injector,\n    @Inject(LR_CONFIG) private config: LifeReadyConfig,\n    private keyFactory: KeyFactoryService,\n    private encryptionService: EncryptionService,\n    private keyGraphService: KeyGraphService,\n    private slip39Service: slip.Slip39Service,\n    private passwordService: PasswordService,\n    private http: HttpClient,\n    private auth: AuthClass,\n    private lrAuth: LifeReadyAuthService\n  ) {\n    super(injector);\n  }\n\n  async verifyEmailContact(email): Promise<{ claimId: string }> {\n    const params = {\n      email,\n    };\n    return this.http\n      .post<any>(\n        `${this.config.authUrl}tp/password-reset/verify-contact/`,\n        params\n      )\n      .toPromise();\n  }\n\n  async verifyContactRespond(\n    claimId: string,\n    claimCode: string\n  ): Promise<string> {\n    const { token } = await this.http\n      .post<{ token }>(`${this.config.authUrl}cove/respond/`, {\n        claim_id: claimId,\n        v_code: claimCode,\n      })\n      .toPromise();\n    return token;\n  }\n\n  async requestReset(\n    password: string,\n    claimId: string,\n    claimToken: string\n  ): Promise<{\n    requestResetResult: RequestResetResult;\n    signUpResult: ISignUpResult;\n  }> {\n    // Generate the key materials\n    const passKeyBundle = await this.passwordService.createPassKeyBundle(\n      password\n    );\n\n    const masterKey = await this.keyFactory.createKey();\n    const wrappedMasterKey = await this.encryptionService.encrypt(\n      passKeyBundle.passKey,\n      masterKey.toJSON(true)\n    );\n\n    // Ephemeral PKC key\n    const prk = await this.keyFactory.createPkcKey();\n    const masterKeyWrappedPrk = await this.encryptionService.encrypt(\n      masterKey,\n      prk.toJSON(true)\n    );\n\n    // API call to setup reset request\n    const requestResetResult = await this.http\n      .post<RequestResetResult>(\n        `${this.config.authUrl}tp/password-reset/request/`,\n        {\n          claimId,\n          claimToken,\n          pass_key_params: passKeyBundle.passKeyParams,\n          pass_idp_params: passKeyBundle.passIdpParams,\n          pass_idp_verifier_pbk: passKeyBundle.passIdpVerifier.toJSON(), // public key\n          wrapped_pass_idp_verifier_prk:\n            passKeyBundle.wrappedPassIdpVerifierPrk,\n          wrapped_master_key: wrappedMasterKey,\n          pbk: prk.toJSON(), // ephemeral public key\n          master_key_wrapped_prk: masterKeyWrappedPrk,\n        }\n      )\n      .toPromise();\n\n    console.log(requestResetResult);\n    console.log(\n      'Using new password: ',\n      this.passwordService.getPassIdpString(passKeyBundle.passIdp)\n    );\n\n    // API call to create user on cognito\n    const signUpResult = await this.auth.signUp({\n      username: requestResetResult.reset_username,\n      password: this.passwordService.getPassIdpString(passKeyBundle.passIdp),\n      clientMetadata: {\n        tp_password_reset_request: JSON.stringify({\n          id: requestResetResult.id,\n          associate_reset_user_token:\n            requestResetResult.associate_reset_user_token,\n        }),\n      },\n    });\n\n    console.log('requestRest done: ', signUpResult);\n\n    return {\n      requestResetResult,\n      signUpResult,\n    };\n  }\n\n  async getResetUser(\n    reload: boolean = false\n  ): Promise<TpPasswordResetUserNode> {\n    if (!reload && this.resetUser) {\n      return this.resetUser;\n    }\n    this.resetUser = await this.lrAuth.loadResetUser();\n    return this.resetUser;\n  }\n\n  private async recoverAssemblyKey(\n    resetUser: TpPasswordResetUserNode\n  ): Promise<JWK.Key> {\n    // Recover the assembly key.\n    let assemblyKeyParams: object;\n\n    const prk = await this.keyGraphService.getKey(resetUser.pxk.id);\n\n    const shares = await Promise.all(\n      resetUser.approvals.map(async (approval) => {\n        const partialAssemblyKey = await this.encryptionService.decrypt(\n          prk,\n          approval.receiverCipherPartialAssemblyKey\n        );\n\n        if (assemblyKeyParams) {\n          if (\n            JSON.stringify(assemblyKeyParams) !==\n            JSON.stringify(partialAssemblyKey.assemblyKeyParams)\n          ) {\n            throw new LrBadStateException(\n              'The assembly key parameters are different between the approvals.'\n            );\n          }\n        } else {\n          assemblyKeyParams = partialAssemblyKey.assemblyKeyParams;\n        }\n        return partialAssemblyKey.slip39.share.mnemonics;\n      })\n    );\n\n    console.log('recoverAssemblyKey()', shares);\n\n    const rawAssemblyKey = await this.slip39Service.recoverSecret(\n      shares,\n      TpPasswordResetService.SLIP39_PASSPHRASE\n    );\n\n    return JWK.asKey({\n      ...assemblyKeyParams,\n      k: rawAssemblyKey,\n    });\n  }\n\n  async completeRequest(newPassword: string): Promise<void> {\n    const resetUser = await this.getResetUser(true);\n    if (resetUser.state !== TpClaimState.APPROVED) {\n      throw new LrBadStateException(\n        'Password reset request has not been approved.'\n      );\n    }\n\n    // --------------------------------------------------------------\n    // Prepare all materials to ensure there are no errors.\n    // --------------------------------------------------------------\n    const assemblyKey = await this.recoverAssemblyKey(resetUser);\n\n    const { rootKey } = await this.encryptionService.decrypt(\n      assemblyKey,\n      resetUser.assemblyCipherData\n    );\n    console.log(rootKey);\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 = await this.encryptionService.encryptToString(\n      masterKey.jwk,\n      rootKeyJwk.toJSON(true)\n    );\n\n    // The new password\n    const newPassIdpResult = await this.keyFactory.derivePassIdp({\n      password: newPassword,\n      ...resetUser.passKey.passIdpParams,\n    });\n\n    const newIdpPassword = this.passwordService.getPassIdpString(\n      newPassIdpResult.jwk\n    );\n\n    // --------------------------------------------------------------\n    // Get assembly key challenge\n    // --------------------------------------------------------------\n    const challenge = (\n      await this.mutate(\n        new LrMutation({\n          mutation: CreateTpAssemblyKeyChallengeMutation,\n          variables: {\n            input: {},\n          },\n        }),\n        {\n          includeKeyGraph: false,\n        }\n      )\n    ).createTpAssemblyKeyChallenge.challenge;\n\n    console.log(challenge);\n\n    // Sign the challenge\n    // Generate a client side nonce that's no in the server's control.\n    challenge.clientNonce = this.keyFactory.randomString(\n      this.CLIENT_NONCE_LENGTH\n    );\n    console.log(challenge);\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.mutate(\n        new LrMutation({\n          mutation: PreCompleteTpPasswordResetRequestMutation,\n          variables: {\n            input: {\n              signedChallenge: JSON.stringify(signedChallenge),\n            },\n          },\n        }),\n        {\n          includeKeyGraph: false,\n        }\n      )\n    ).preCompleteTpPasswordResetRequest.idpPassword;\n\n    // --------------------------------------------------------------\n    // Login as the original user using new temporary password\n    // --------------------------------------------------------------\n    // At this point, the original account's password has been changed\n    // to a temporary password. It is no longer possible for the user\n    // to use the original password to login. Any successful login\n    // can only be using the temporary password. So it's safe to assume\n    // that we want to \"complete\" the password reset.\n\n    // The maybe 2FA so we listen for the auth event from Amplify.\n    const retPromise = new Promise<void>((resolve) => {\n      const listener = async (data) => {\n        if (data.payload.event !== 'signIn') {\n          return;\n        }\n\n        Hub.remove('auth', listener);\n\n        console.log(data.payload);\n\n        await this.auth.signIn(resetUser.username, newIdpPassword);\n\n        // Switch over to the new set of keys\n        await this.mutate(\n          new LrMutation({\n            mutation: CompleteTpPasswordResetRequestMutation,\n            variables: {\n              input: {\n                masterKeyWrappedRootKey,\n                masterKeyId: masterKey.id,\n              },\n            },\n          })\n        );\n\n        resolve();\n      };\n\n      Hub.listen('auth', listener);\n    });\n\n    // Signin as the original user. Password has been reset to temporary one. It should return\n    // with NEW_PASSWORD_REQUIRED\n    let user = await this.auth.signIn(resetUser.username, tempIdpPassword, {\n      noProxy: 'true',\n    });\n\n    if (user.challengeName !== 'NEW_PASSWORD_REQUIRED') {\n      throw new LrException({\n        message:\n          'Internal error. Expecting Cognito to have done a password reset after call to PreCompleteTpPasswordResetRequestMutation.',\n      });\n    }\n\n    // Set new password on Idp\n    // the awsFetch() function passes NEW_PASSWORD_REQUIRED directly to AWS without\n    // going through the proxy.\n    user = await this.auth.completeNewPassword(user, newIdpPassword, {});\n\n    return retPromise;\n  }\n}\n"]}
129
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tp-password-reset-user.service.js","sourceRoot":"/opt/atlassian/pipelines/agent/build/projects/core/src/","sources":["lib/trusted-parties/tp-password-reset-user.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Hub } from '@aws-amplify/core';\nimport { Inject, Injectable, Injector, NgZone } from '@angular/core';\nimport { EncryptionService } from '../cryptography/encryption.service';\nimport { KeyGraphService } from '../cryptography/key-graph.service';\nimport { LifeReadyConfig, LR_CONFIG } from '../life-ready.config';\nimport * as slip from '../cryptography/slip39.service';\nimport { JWK } from 'node-jose';\nimport { LrBadStateException, LrException } from '../_common/exceptions';\nimport {\n  CompleteTpPasswordResetRequestMutation,\n  CreateTpAssemblyKeyChallengeMutation,\n  PreCompleteTpPasswordResetRequestMutation,\n} from './tp-password-reset.gql';\nimport { PasswordService } from '../auth/password.service';\nimport { HttpClient } from '@angular/common/http';\nimport { AuthClass } from '@aws-amplify/auth/lib-esm/Auth';\nimport {\n  RequestResetResult,\n  TpPasswordResetService,\n} from './tp-password-reset.service';\nimport { ISignUpResult } from 'amazon-cognito-identity-js';\nimport { LifeReadyAuthService } from '../auth/life-ready-auth.service';\nimport { KeyFactoryService } from '../cryptography/key-factory.service';\nimport { TpClaimState, TpPasswordResetUserNode } from '../api/types';\nimport { LrMutation, LrService } from '../api/lr-graphql';\nimport { RunOutsideAngular } from '../_common/run-outside-angular';\nimport { TpPasswordResetUser } from '../auth/auth.types';\n\n@RunOutsideAngular({\n  ngZoneName: 'ngZone',\n})\n@Injectable({\n  providedIn: 'root',\n})\nexport class TpPasswordResetUserService extends LrService {\n  constructor(\n    private ngZone: NgZone,\n    private injector: Injector,\n    @Inject(LR_CONFIG) private config: LifeReadyConfig,\n    private keyFactory: KeyFactoryService,\n    private encryptionService: EncryptionService,\n    private keyGraphService: KeyGraphService,\n    private slip39Service: slip.Slip39Service,\n    private passwordService: PasswordService,\n    private http: HttpClient,\n    private auth: AuthClass,\n    private lrAuth: LifeReadyAuthService\n  ) {\n    super(injector);\n  }\n\n  async verifyEmailContact(email): Promise<{ claimId: string }> {\n    const params = {\n      email,\n    };\n    return this.http\n      .post<any>(\n        `${this.config.authUrl}tp/password-reset/verify-contact/`,\n        params\n      )\n      .toPromise();\n  }\n\n  async verifyContactRespond(\n    claimId: string,\n    claimCode: string\n  ): Promise<string> {\n    const { token } = await this.http\n      .post<{ token }>(`${this.config.authUrl}cove/respond/`, {\n        claim_id: claimId,\n        v_code: claimCode,\n      })\n      .toPromise();\n    return token;\n  }\n\n  async requestReset(\n    password: string,\n    claimId: string,\n    claimToken: string\n  ): Promise<{\n    requestResetResult: RequestResetResult;\n    signUpResult: ISignUpResult;\n  }> {\n    // Generate the key materials\n    const passKeyBundle = await this.passwordService.createPassKeyBundle(\n      password\n    );\n\n    const masterKey = await this.keyFactory.createKey();\n    const wrappedMasterKey = await this.encryptionService.encrypt(\n      passKeyBundle.passKey,\n      masterKey.toJSON(true)\n    );\n\n    // Ephemeral PKC key\n    const prk = await this.keyFactory.createPkcKey();\n    const masterKeyWrappedPrk = await this.encryptionService.encrypt(\n      masterKey,\n      prk.toJSON(true)\n    );\n\n    // API call to setup reset request\n    const requestResetResult = await this.http\n      .post<RequestResetResult>(\n        `${this.config.authUrl}tp/password-reset/request/`,\n        {\n          claimId,\n          claimToken,\n          pass_key_params: passKeyBundle.passKeyParams,\n          pass_idp_params: passKeyBundle.passIdpParams,\n          pass_idp_verifier_pbk: passKeyBundle.passIdpVerifier.toJSON(), // public key\n          wrapped_pass_idp_verifier_prk:\n            passKeyBundle.wrappedPassIdpVerifierPrk,\n          wrapped_master_key: wrappedMasterKey,\n          pbk: prk.toJSON(), // ephemeral public key\n          master_key_wrapped_prk: masterKeyWrappedPrk,\n        }\n      )\n      .toPromise();\n\n    console.log(requestResetResult);\n    console.log(\n      'Using new password: ',\n      this.passwordService.getPassIdpString(passKeyBundle.passIdp)\n    );\n\n    // API call to create user on cognito\n    const signUpResult = await this.auth.signUp({\n      username: requestResetResult.reset_username,\n      password: this.passwordService.getPassIdpString(passKeyBundle.passIdp),\n      clientMetadata: {\n        tp_password_reset_request: JSON.stringify({\n          id: requestResetResult.id,\n          associate_reset_user_token:\n            requestResetResult.associate_reset_user_token,\n        }),\n      },\n    });\n\n    console.log('requestRest done: ', signUpResult);\n\n    return {\n      requestResetResult,\n      signUpResult,\n    };\n  }\n}\n"]}
@@ -0,0 +1,4 @@
1
+ export const TP_PASSWORD_RESET_CLIENT_NONCE_LENGTH = 32;
2
+ export const TP_PASSWORD_RESET_SLIP39_PASSPHRASE = 'lifeready';
3
+ export const TP_PASSWORD_RESET_USERNAME_SUFFIX = '.tp_password_reset';
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHAtcGFzc3dvcmQtcmVzZXQuY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6Ii9vcHQvYXRsYXNzaWFuL3BpcGVsaW5lcy9hZ2VudC9idWlsZC9wcm9qZWN0cy9jb3JlL3NyYy8iLCJzb3VyY2VzIjpbImxpYi90cnVzdGVkLXBhcnRpZXMvdHAtcGFzc3dvcmQtcmVzZXQuY29uc3RhbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBQyxNQUFNLHFDQUFxQyxHQUFHLEVBQUUsQ0FBQztBQUN4RCxNQUFNLENBQUMsTUFBTSxtQ0FBbUMsR0FBRyxXQUFXLENBQUM7QUFDL0QsTUFBTSxDQUFDLE1BQU0saUNBQWlDLEdBQUcsb0JBQW9CLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgVFBfUEFTU1dPUkRfUkVTRVRfQ0xJRU5UX05PTkNFX0xFTkdUSCA9IDMyO1xuZXhwb3J0IGNvbnN0IFRQX1BBU1NXT1JEX1JFU0VUX1NMSVAzOV9QQVNTUEhSQVNFID0gJ2xpZmVyZWFkeSc7XG5leHBvcnQgY29uc3QgVFBfUEFTU1dPUkRfUkVTRVRfVVNFUk5BTUVfU1VGRklYID0gJy50cF9wYXNzd29yZF9yZXNldCc7XG4iXX0=
@@ -1,4 +1,3 @@
1
- var TpPasswordResetService_1;
2
1
  import { __awaiter, __decorate, __rest } from "tslib";
3
2
  import { Injectable, Injector, NgZone } from '@angular/core';
4
3
  import { KeyService } from '../cryptography/key.service';
@@ -10,6 +9,7 @@ import { LrBadArgumentException, LrBadLogicException, } from '../_common/excepti
10
9
  import { KeyFactoryService } from '../cryptography/key-factory.service';
11
10
  import { LrMutation, LrService } from '../api/lr-graphql';
12
11
  import { RunOutsideAngular } from '../_common/run-outside-angular';
12
+ import { TP_PASSWORD_RESET_SLIP39_PASSPHRASE } from './tp-password-reset.constants';
13
13
  import * as i0 from "@angular/core";
14
14
  import * as i1 from "../cryptography/key.service";
15
15
  import * as i2 from "../cryptography/key-factory.service";
@@ -24,7 +24,7 @@ export class CreateTpPasswordResetInput {
24
24
  }
25
25
  export class UpdateTpPasswordResetInput extends CreateTpPasswordResetInput {
26
26
  }
27
- let TpPasswordResetService = TpPasswordResetService_1 = class TpPasswordResetService extends LrService {
27
+ let TpPasswordResetService = class TpPasswordResetService extends LrService {
28
28
  constructor(ngZone, injector, keyService, keyFactory, encryptionService, keyGraph, slip39Service) {
29
29
  super(injector);
30
30
  this.ngZone = ngZone;
@@ -211,7 +211,7 @@ let TpPasswordResetService = TpPasswordResetService_1 = class TpPasswordResetSer
211
211
  }
212
212
  slipAssembly.addSubAssembly(new slip.SubAssembly(index, sa.quorum, approverCount));
213
213
  });
214
- yield this.slip39Service.generateShares(rawAssemblyKey, TpPasswordResetService_1.SLIP39_PASSPHRASE, slipAssembly);
214
+ yield this.slip39Service.generateShares(rawAssemblyKey, TP_PASSWORD_RESET_SLIP39_PASSPHRASE, slipAssembly);
215
215
  return slipAssembly;
216
216
  });
217
217
  }
@@ -275,7 +275,6 @@ let TpPasswordResetService = TpPasswordResetService_1 = class TpPasswordResetSer
275
275
  });
276
276
  }
277
277
  };
278
- TpPasswordResetService.SLIP39_PASSPHRASE = 'lifeready';
279
278
  TpPasswordResetService.ɵprov = i0.ɵɵdefineInjectable({ factory: function TpPasswordResetService_Factory() { return new TpPasswordResetService(i0.ɵɵinject(i0.NgZone), i0.ɵɵinject(i0.INJECTOR), i0.ɵɵinject(i1.KeyService), i0.ɵɵinject(i2.KeyFactoryService), i0.ɵɵinject(i3.EncryptionService), i0.ɵɵinject(i4.KeyGraphService), i0.ɵɵinject(i5.Slip39Service)); }, token: TpPasswordResetService, providedIn: "root" });
280
279
  TpPasswordResetService.decorators = [
281
280
  { type: Injectable, args: [{
@@ -291,10 +290,10 @@ TpPasswordResetService.ctorParameters = () => [
291
290
  { type: KeyGraphService },
292
291
  { type: slip.Slip39Service }
293
292
  ];
294
- TpPasswordResetService = TpPasswordResetService_1 = __decorate([
293
+ TpPasswordResetService = __decorate([
295
294
  RunOutsideAngular({
296
295
  ngZoneName: 'ngZone',
297
296
  })
298
297
  ], TpPasswordResetService);
299
298
  export { TpPasswordResetService };
300
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tp-password-reset.service.js","sourceRoot":"/opt/atlassian/pipelines/agent/build/projects/core/src/","sources":["lib/trusted-parties/tp-password-reset.service.ts"],"names":[],"mappings":";;AAAA,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAC7D,OAAO,EAAE,UAAU,EAAE,MAAM,6BAA6B,CAAC;AACzD,OAAO,EAAE,iBAAiB,EAAE,MAAM,oCAAoC,CAAC;AACvE,OAAO,EACL,6BAA6B,EAC7B,6BAA6B,EAC7B,oBAAoB,EACpB,6BAA6B,EAC7B,oCAAoC,GACrC,MAAM,yBAAyB,CAAC;AACjC,OAAO,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AACpE,OAAO,KAAK,IAAI,MAAM,gCAAgC,CAAC;AACvD,OAAO,EACL,sBAAsB,EACtB,mBAAmB,GACpB,MAAM,uBAAuB,CAAC;AAI/B,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EAAoB,UAAU,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAE5E,OAAO,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAC;;;;;;;AAEnE,MAAM,OAAO,wBAAwB;CAKpC;AAED,MAAM,OAAO,wBAAyB,SAAQ,wBAAwB;CAErE;AAED,MAAM,OAAO,0BAA0B;CAItC;AAED,MAAM,OAAO,0BAA2B,SAAQ,0BAA0B;CAEzE;IAmDY,sBAAsB,oCAAtB,sBAAuB,SAAQ,SAAS;IAGnD,YACU,MAAc,EACd,QAAkB,EAClB,UAAsB,EACtB,UAA6B,EAC7B,iBAAoC,EACpC,QAAyB,EACzB,aAAiC;QAEzC,KAAK,CAAC,QAAQ,CAAC,CAAC;QARR,WAAM,GAAN,MAAM,CAAQ;QACd,aAAQ,GAAR,QAAQ,CAAU;QAClB,eAAU,GAAV,UAAU,CAAY;QACtB,eAAU,GAAV,UAAU,CAAmB;QAC7B,sBAAiB,GAAjB,iBAAiB,CAAmB;QACpC,aAAQ,GAAR,QAAQ,CAAiB;QACzB,kBAAa,GAAb,aAAa,CAAoB;IAG3C,CAAC;IAEK,QAAQ;;YACZ,OAAO,CACL,MAAM,IAAI,CAAC,KAAK,CAAC;gBACf,KAAK,EAAE,oBAAoB;aAC5B,CAAC,CACH,CAAC,eAAe,CAAC;QACpB,CAAC;KAAA;IAED,WAAW,CAAC,KAAiC;QAC3C,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC,CAAC;IACtD,CAAC;IAEK,mBAAmB,CAAC,KAAiC;;YACzD,MAAM,EAAE,aAAa,EAAE,GAAG,MAAM,IAAI,CAAC,YAAY,CAC/C,KAAK,EACL,CAAO,cAAc,EAAE,EAAE;gBACvB,OAAO,IAAI,CAAC,aAAa,CACvB,KAAK,CAAC,mBAAmB,EACzB,KAAK,CAAC,MAAM,EACZ,cAAc,CACf,CAAC;YACJ,CAAC,CAAA,CACF,CAAC;YAEF,OAAO,IAAI,UAAU,CAAC;gBACpB,QAAQ,EAAE,6BAA6B;gBACvC,SAAS,EAAE;oBACT,KAAK,EAAE,aAAa;iBACrB;aACF,CAAC,CAAC;QACL,CAAC;KAAA;IAED,WAAW;QACT,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,mBAAmB,EAAE,CAAC,CAAC;IACjD,CAAC;IAED,mBAAmB;QACjB,OAAO,IAAI,UAAU,CAAC;YACpB,QAAQ,EAAE,6BAA6B;SACxC,CAAC,CAAC;IACL,CAAC;IAED,WAAW,CAAC,KAAiC;QAC3C,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC,CAAC;IACtD,CAAC;IAEK,mBAAmB,CAAC,KAAiC;;YACzD,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,QAAQ,EAAE,CAAC;YAE5C,MAAM,EACJ,aAAa,EACb,UAAU,EACV,YAAY,EACZ,iBAAiB,GAClB,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,CAAO,cAAc,EAAE,EAAE;gBAC1D,OAAO,IAAI,CAAC,aAAa,CACvB,KAAK,CAAC,mBAAmB,CAAC,MAAM,CAAC,KAAK,CAAC,mBAAmB,CAAC,EAC3D,KAAK,CAAC,MAAM,EACZ,cAAc,CACf,CAAC;YACJ,CAAC,CAAA,CAAC,CAAC;YAEH,MAAM,mBAAmB,GAAG,MAAM,OAAO,CAAC,GAAG,CAC3C,KAAK,CAAC,mBAAmB,CAAC,GAAG,CAAC,CAAO,EAAE,EAAE,OAAO,EAAE,EAAE;gBAClD,MAAM,iBAAiB,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,eAAe,CACpE,UAAU,EACV;oBACE,IAAI,EAAE,EAAE,CAAC,IAAI;iBACd,CACF,CAAC;gBAEF,gCAAgC;gBAChC,MAAM,UAAU,GAAG,aAAa,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,IAAI,CAChE,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,CACjC,CAAC,IAAI,CAAC;gBAEP,sCAAsC;gBACtC,MAAM,eAAe,GAAG,EAAE,CAAC;gBAC3B,MAAM,eAAe,GAAG,EAAE,CAAC;gBAE3B,EAAE,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,EAAE,EAAE,EAAE;;oBAC5B,MAAM,QAAQ,SAAG,UAAU,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAC9C,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,CACpC,0CAAE,IAAI,CAAC;oBACR,IAAI,QAAQ,EAAE;wBACZ,eAAe,CAAC,IAAI,CAAC;4BACnB,EAAE;4BACF,UAAU,EAAE,QAAQ,CAAC,EAAE;yBACxB,CAAC,CAAC;qBACJ;yBAAM;wBACL,eAAe,CAAC,IAAI,CAAC;4BACnB,EAAE;yBACH,CAAC,CAAC;qBACJ;gBACH,CAAC,CAAC,CAAC;gBAEH,OAAO;oBACL,aAAa,EAAE,EAAE,CAAC,EAAE;oBACpB,YAAY,EAAE,EAAE,CAAC,YAAY;oBAC7B,MAAM,EAAE,EAAE,CAAC,MAAM;oBACjB,iBAAiB;oBACjB,eAAe,EAAE,MAAM,OAAO,CAAC,GAAG,CAChC,eAAe,CAAC,GAAG,CAAC,CAAO,EAAE,EAAE,EAAE,EAAE,aAAa,EAAE,EAAE;wBAClD,OAAA,IAAI,CAAC,eAAe,CAAC;4BACnB,EAAE;4BACF,aAAa;4BACb,OAAO,EAAE,OAAO,GAAG,KAAK,CAAC,mBAAmB,CAAC,MAAM;4BACnD,YAAY;4BACZ,iBAAiB;4BACjB,UAAU;yBACX,CAAC,CAAA;sBAAA,CACH,CACF;oBACD,eAAe,EAAE,MAAM,OAAO,CAAC,GAAG,CAChC,eAAe,CAAC,GAAG,CAAC,CAAO,EAAE,EAAE,EAAE,UAAU,EAAE,EAAE,aAAa,EAAE,EAAE;wBAC9D,OAAA,IAAI,CAAC,eAAe,CAAC;4BACnB,UAAU;4BACV,EAAE;4BACF,aAAa,EAAE,aAAa,GAAG,eAAe,CAAC,MAAM;4BACrD,OAAO,EAAE,OAAO,GAAG,KAAK,CAAC,mBAAmB,CAAC,MAAM;4BACnD,YAAY;4BACZ,iBAAiB;4BACjB,UAAU;yBACX,CAAC,CAAA;sBAAA,CACH,CACF;iBACF,CAAC;YACJ,CAAC,CAAA,CAAC,CACH,CAAC;YAEF,OAAO,IAAI,UAAU,CAAC;gBACpB,QAAQ,EAAE,6BAA6B;gBACvC,SAAS,EAAE;oBACT,KAAK,kCACA,aAAa,KAChB,QAAQ,kCACH,aAAa,CAAC,QAAQ,KACzB,mBAAmB,MAEtB;iBACF;aACF,CAAC,CAAC;QACL,CAAC;KAAA;IAED,kBAAkB;QAChB,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,0BAA0B,EAAE,CAAC,CAAC;IACxD,CAAC;IAED,0BAA0B;QACxB,OAAO,IAAI,UAAU,CAAC;YACpB,QAAQ,EAAE,oCAAoC;SAC/C,CAAC,CAAC;IACL,CAAC;IAED,iBAAiB,CAAC,SAAmB;QACnC,yCAAyC;QACzC,KAAK,MAAM,EAAE,IAAI,SAAS,EAAE;YAC1B,IAAI,CAAC,EAAE,CAAC,oBAAoB,CAAC,aAAa,CAAC,WAAW,EAAE;gBACtD,MAAM,GAAG,GAAG,MAAM,EAAE,CAAC,KAAK,CAAC,QAAQ,4BAA4B,CAAC;gBAChE,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;gBACjB,MAAM,IAAI,sBAAsB,CAAC,GAAG,CAAC,CAAC;aACvC;SACF;IACH,CAAC;IAEa,eAAe,CAAC,EAC5B,UAAU,EACV,EAAE,EACF,aAAa,EACb,OAAO,EACP,YAAY,EACZ,iBAAiB,EACjB,UAAU,GASX;;YACC,IAAI,CAAC,EAAE,CAAC,oBAAoB,CAAC,aAAa,CAAC,WAAW,EAAE;gBACtD,MAAM,IAAI,sBAAsB,CAC9B,MAAM,EAAE,CAAC,KAAK,CAAC,QAAQ,wDAAwD,CAChF,CAAC;aACH;YAED,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC;YACpD,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,MAAM,CAC9C,EAAE,CAAC,oBAAoB,CAAC,aAAa,CAAC,WAAW,CAAC,EAAE,CACrD,CAAC;YACF,8BAA8B;YAC9B,MAAM,6BAA6B,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,eAAe,CAChF,aAAa,CAAC,GAAG,EACjB,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,CACvB,CAAC;YACF,mCAAmC;YACnC,MAAM,0BAA0B,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,eAAe,CAC7E,UAAU,EACV,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,CACvB,CAAC;YAEF,MAAM,MAAM,GAAG,YAAY,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;YACnD,IAAI,MAAM,CAAC,KAAK,KAAK,OAAO,EAAE;gBAC5B,WAAW;gBACX,MAAM,IAAI,mBAAmB,CAC3B,uDAAuD,CACxD,CAAC;aACH;YAED,8DAA8D;YAC9D,MAAM,KAAK,GACT,MAAM,CAAC,SAAS,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;YAE3E,MAAM,kBAAkB,GAAuB;gBAC7C,MAAM,EAAE;oBACN,KAAK;oBACL,WAAW,EAAE;wBACX,MAAM,EAAE,MAAM,CAAC,SAAS;wBACxB,IAAI,EAAE,MAAM,CAAC,IAAI;qBAClB;iBACF;gBACD,iBAAiB;aAClB,CAAC;YAEF,OAAO,CAAC,GAAG,CAAC,oBAAoB,EAAE,kBAAkB,CAAC,CAAC;YAEtD,OAAO;gBACL,eAAe,EAAE,aAAa,CAAC,EAAE;gBACjC,6BAA6B;gBAC7B,0BAA0B;gBAC1B,gBAAgB,EAAE,MAAM,IAAI,CAAC,iBAAiB,CAAC,eAAe,CAC5D,SAAS,EACT,EAAE,CAAC,EAAE,KAAK,EAAE,CACb;gBACD,wBAAwB,EAAE,EAAE;gBAC5B,8BAA8B,EAAE,MAAM,IAAI,CAAC,iBAAiB,CAAC,eAAe,CAC1E,SAAS,EACT,kBAAkB,CACnB;gBACD,UAAU,EAAE,UAAU,IAAI,KAAK,CAAC;gBAChC,IAAI,EAAE,UAAU,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE;aAClC,CAAC;QACJ,CAAC;KAAA;IAED,iBAAiB;IACH,aAAa,CACzB,aAAa,EACb,cAAsB,EACtB,cAAsB;;YAEtB,gDAAgD;YAChD,IAAI,aAAa,CAAC,MAAM,GAAG,cAAc,EAAE;gBACzC,MAAM,IAAI,sBAAsB,CAC9B,0CAA0C,CAC3C,CAAC;aACH;YAED,MAAM,YAAY,GAAG,IAAI,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC;YAEvD,aAAa,CAAC,OAAO,CAAC,CAAC,EAAE,EAAE,KAAK,EAAE,EAAE;gBAClC,IAAI,aAAa,GAAG,EAAE,CAAC,WAAW,CAAC,MAAM,CAAC;gBAE1C,gFAAgF;gBAChF,4CAA4C;gBAC5C,IAAI,EAAE,CAAC,MAAM,KAAK,CAAC,EAAE;oBACnB,aAAa,GAAG,CAAC,CAAC;iBACnB;gBACD,YAAY,CAAC,cAAc,CACzB,IAAI,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,EAAE,CAAC,MAAM,EAAE,aAAa,CAAC,CACtD,CAAC;YACJ,CAAC,CAAC,CAAC;YAEH,MAAM,IAAI,CAAC,aAAa,CAAC,cAAc,CACrC,cAAc,EACd,wBAAsB,CAAC,iBAAiB,EACxC,YAAY,CACb,CAAC;YACF,OAAO,YAAY,CAAC;QACtB,CAAC;KAAA;IAEa,YAAY,CACxB,KAAiC,EACjC,kBAAkB;;YAElB,qBAAqB;YACrB,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,mBAAmB,EAAE,CAAC;YAC9D,MAAM,UAAU,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC;YACrD,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC;YACtD,MAAM,KAA8C,WAAW,CAAC,MAAM,CACpE,IAAI,CACE,EAFF,EAAE,CAAC,EAAE,cAAc,OAEjB,EAFsB,iBAAiB,cAAzC,KAA2C,CAEzC,CAAC;YACT,MAAM,sBAAsB,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,gBAAgB,EAAE,CAAC;YACxE,MAAM,6BAA6B,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,eAAe,CAChF,WAAW,EACX,sBAAsB,CAAC,MAAM,CAAC,IAAI,CAAC,CACpC,CAAC;YAEF,MAAM,0BAA0B,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,eAAe,CAC7E,SAAS,CAAC,GAAG,EACb,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,CACxB,CAAC;YACF,MAAM,4BAA4B,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,eAAe,CAC/E,UAAU,EACV,WAAW,CAAC,MAAM,CAAC,IAAI,CAAC,CACzB,CAAC;YAEF,2CAA2C;YAC3C,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,iBAAiB,EAAE,CAAC;YAE1D,MAAM,kBAAkB,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,eAAe,CACrE,WAAW,EACX;gBACE,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC;aAClC,CACF,CAAC;YAEF,MAAM,YAAY,GAAG,MAAM,kBAAkB,CAAC,cAAc,CAAC,CAAC;YAC9D,0GAA0G;YAE1G,MAAM,mBAAmB,GAAG,MAAM,OAAO,CAAC,GAAG,CAC3C,KAAK,CAAC,mBAAmB,CAAC,GAAG,CAAC,CAAO,EAAE,EAAE,OAAO,EAAE,EAAE;gBAClD,MAAM,iBAAiB,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,eAAe,CACpE,UAAU,EACV;oBACE,IAAI,EAAE,EAAE,CAAC,IAAI;iBACd,CACF,CAAC;gBAEF,OAAO;oBACL,YAAY,EAAE,EAAE,CAAC,YAAY;oBAC7B,MAAM,EAAE,EAAE,CAAC,MAAM;oBACjB,iBAAiB;oBACjB,eAAe,EAAE,MAAM,OAAO,CAAC,GAAG,CAChC,EAAE,CAAC,WAAW,CAAC,GAAG,CAAC,CAAO,UAAU,EAAE,aAAa,EAAE,EAAE;wBACrD,OAAA,IAAI,CAAC,eAAe,CAAC;4BACnB,EAAE,EAAE,UAAU;4BACd,aAAa;4BACb,OAAO;4BACP,YAAY;4BACZ,iBAAiB;4BACjB,UAAU;yBACX,CAAC,CAAA;sBAAA,CACH,CACF;iBACF,CAAC;YACJ,CAAC,CAAA,CAAC,CACH,CAAC;YAEF,OAAO;gBACL,UAAU;gBACV,YAAY;gBACZ,iBAAiB;gBACjB,aAAa,EAAE;oBACb,QAAQ,EAAE;wBACR,YAAY,EAAE,KAAK,CAAC,YAAY;wBAChC,MAAM,EAAE,KAAK,CAAC,MAAM;wBACpB,WAAW,EAAE,SAAS,CAAC,EAAE;wBACzB,0BAA0B;wBAC1B,4BAA4B;wBAC5B,iBAAiB,EAAE,EAAE;wBACrB,kBAAkB;wBAClB,mBAAmB;wBACnB,sBAAsB,EAAE,IAAI,CAAC,SAAS,CACpC,sBAAsB,CAAC,MAAM,EAAE,CAChC;wBACD,6BAA6B;qBAC9B;iBACF;aACF,CAAC;QACJ,CAAC;KAAA;CACF,CAAA;AAlYe,wCAAiB,GAAG,WAAW,CAAC;;;YAJ/C,UAAU,SAAC;gBACV,UAAU,EAAE,MAAM;aACnB;;;YA7F8B,MAAM;YAAhB,QAAQ;YACpB,UAAU;YAkBV,iBAAiB;YAjBjB,iBAAiB;YAQjB,eAAe;YACZ,IAAI,CA6FgB,aAAa;;AAVhC,sBAAsB;IANlC,iBAAiB,CAAC;QACjB,UAAU,EAAE,QAAQ;KACrB,CAAC;GAIW,sBAAsB,CAmYlC;SAnYY,sBAAsB","sourcesContent":["import { Injectable, Injector, NgZone } from '@angular/core';\nimport { KeyService } from '../cryptography/key.service';\nimport { EncryptionService } from '../cryptography/encryption.service';\nimport {\n  CreateTpPasswordResetMutation,\n  DeleteTpPasswordResetMutation,\n  TpPasswordResetQuery,\n  UpdateTpPasswordResetMutation,\n  CancelTpPasswordResetRequestMutation,\n} from './tp-password-reset.gql';\nimport { KeyGraphService } from '../cryptography/key-graph.service';\nimport * as slip from '../cryptography/slip39.service';\nimport {\n  LrBadArgumentException,\n  LrBadLogicException,\n} from '../_common/exceptions';\nimport { PartialAssemblyKey } from '../scenario/scenario.types';\nimport { JWK } from 'node-jose';\nimport { Key } from '../cryptography/cryptography.types';\nimport { KeyFactoryService } from '../cryptography/key-factory.service';\nimport { LrGraphQLService, LrMutation, LrService } from '../api/lr-graphql';\nimport { TpNode } from '../api/types';\nimport { RunOutsideAngular } from '../_common/run-outside-angular';\n\nexport class CreateSubAssembliesInput {\n  name: string;\n  quorum: number;\n  singleReject: boolean;\n  approverTps: TpNode[];\n}\n\nexport class UpdateSubAssembliesInput extends CreateSubAssembliesInput {\n  id: string;\n}\n\nexport class CreateTpPasswordResetInput {\n  quorum: number;\n  singleReject: boolean;\n  createSubAssemblies: CreateSubAssembliesInput[];\n}\n\nexport class UpdateTpPasswordResetInput extends CreateTpPasswordResetInput {\n  updateSubAssemblies: UpdateSubAssembliesInput[];\n}\n\nexport interface TpAssemblyApprovers {\n  id: string;\n  tp: {\n    id: string;\n  };\n  sharedKey: Key;\n  sharedCipherData?: string;\n  sharedCipherDataClearJson?: any;\n  sharedCipherApprovalData?: string;\n  sharedCipherApprovalDataClearJson?: any;\n}\n\nexport interface TpSubAssembly {\n  id: string;\n  singleReject: boolean;\n  quorum: number;\n  subjectCipherData: string;\n  plainSubjectCipherData: any;\n  approvers: TpAssemblyApprovers[];\n}\n\nexport interface TpAssembly {\n  singleReject: boolean;\n  quorum: number;\n  subjectKey: Key;\n  assemblyKey: Key;\n  assemblyCipherData: string;\n  plainAssemblyCipherData: any;\n  subAssemblies: TpSubAssembly[];\n}\n\nexport interface TpPasswordReset {\n  id: string;\n  assembly: TpAssembly;\n  applied: boolean;\n}\n\nexport interface RequestResetResult {\n  id: string;\n  associate_reset_user_token: string;\n  reset_username: string;\n}\n\n@RunOutsideAngular({\n  ngZoneName: 'ngZone',\n})\n@Injectable({\n  providedIn: 'root',\n})\nexport class TpPasswordResetService extends LrService {\n  public static SLIP39_PASSPHRASE = 'lifeready';\n\n  constructor(\n    private ngZone: NgZone,\n    private injector: Injector,\n    private keyService: KeyService,\n    private keyFactory: KeyFactoryService,\n    private encryptionService: EncryptionService,\n    private keyGraph: KeyGraphService,\n    private slip39Service: slip.Slip39Service\n  ) {\n    super(injector);\n  }\n\n  async getReset() {\n    return (\n      await this.query({\n        query: TpPasswordResetQuery,\n      })\n    ).tpPasswordReset;\n  }\n\n  createReset(input: CreateTpPasswordResetInput) {\n    return this.mutate(this.createResetMutation(input));\n  }\n\n  async createResetMutation(input: CreateTpPasswordResetInput) {\n    const { mutationInput } = await this._createReset(\n      input,\n      async (rawAssemblyKey) => {\n        return this.prepareSlip39(\n          input.createSubAssemblies,\n          input.quorum,\n          rawAssemblyKey\n        );\n      }\n    );\n\n    return new LrMutation({\n      mutation: CreateTpPasswordResetMutation,\n      variables: {\n        input: mutationInput,\n      },\n    });\n  }\n\n  deleteReset() {\n    return this.mutate(this.deleteResetMutation());\n  }\n\n  deleteResetMutation() {\n    return new LrMutation({\n      mutation: DeleteTpPasswordResetMutation,\n    });\n  }\n\n  updateReset(input: UpdateTpPasswordResetInput) {\n    return this.mutate(this.updateResetMutation(input));\n  }\n\n  async updateResetMutation(input: UpdateTpPasswordResetInput) {\n    const passwordReset = await this.getReset();\n\n    const {\n      mutationInput,\n      subjectKey,\n      slipAssembly,\n      assemblyKeyParams,\n    } = await this._createReset(input, async (rawAssemblyKey) => {\n      return this.prepareSlip39(\n        input.createSubAssemblies.concat(input.updateSubAssemblies),\n        input.quorum,\n        rawAssemblyKey\n      );\n    });\n\n    const updateSubAssemblies = await Promise.all(\n      input.updateSubAssemblies.map(async (sa, saIndex) => {\n        const subjectCipherData = await this.encryptionService.encryptToString(\n          subjectKey,\n          {\n            name: sa.name,\n          }\n        );\n\n        // Get the existing sub-assembly\n        const existingSa = passwordReset.assembly.subAssemblies.edges.find(\n          (edge) => edge.node.id === sa.id\n        ).node;\n\n        // Get approvers that do not exist yet\n        const createApprovers = [];\n        const updateApprovers = [];\n\n        sa.approverTps.forEach((tp) => {\n          const approver = existingSa.approvers.edges.find(\n            (edge) => edge.node.tp.id === tp.id\n          )?.node;\n          if (approver) {\n            updateApprovers.push({\n              tp,\n              approverId: approver.id,\n            });\n          } else {\n            createApprovers.push({\n              tp,\n            });\n          }\n        });\n\n        return {\n          subAssemblyId: sa.id,\n          singleReject: sa.singleReject,\n          quorum: sa.quorum,\n          subjectCipherData,\n          createApprovers: await Promise.all(\n            createApprovers.map(async ({ tp }, approverIndex) =>\n              this.prepareApprover({\n                tp,\n                approverIndex,\n                saIndex: saIndex + input.createSubAssemblies.length, // slipAssembly is all sub-assemblies combined\n                slipAssembly,\n                assemblyKeyParams,\n                subjectKey,\n              })\n            )\n          ),\n          updateApprovers: await Promise.all(\n            updateApprovers.map(async ({ tp, approverId }, approverIndex) =>\n              this.prepareApprover({\n                approverId,\n                tp,\n                approverIndex: approverIndex + createApprovers.length,\n                saIndex: saIndex + input.createSubAssemblies.length, // slipAssembly is all sub-assemblies combined\n                slipAssembly,\n                assemblyKeyParams,\n                subjectKey,\n              })\n            )\n          ),\n        };\n      })\n    );\n\n    return new LrMutation({\n      mutation: UpdateTpPasswordResetMutation,\n      variables: {\n        input: {\n          ...mutationInput,\n          assembly: {\n            ...mutationInput.assembly,\n            updateSubAssemblies,\n          },\n        },\n      },\n    });\n  }\n\n  cancelResetRequest() {\n    return this.mutate(this.cancelResetRequestMutation());\n  }\n\n  cancelResetRequestMutation() {\n    return new LrMutation({\n      mutation: CancelTpPasswordResetRequestMutation,\n    });\n  }\n\n  validateApprovers(approvers: TpNode[]): void {\n    // Ensure all approvers have mkSharedKey.\n    for (const tp of approvers) {\n      if (!tp.currentUserSharedKey.userSharedKey.mkSharedKey) {\n        const msg = `tp ${tp.other.username} does not have mkSharedKey`;\n        console.log(msg);\n        throw new LrBadArgumentException(msg);\n      }\n    }\n  }\n\n  private async prepareApprover({\n    approverId,\n    tp,\n    approverIndex,\n    saIndex,\n    slipAssembly,\n    assemblyKeyParams,\n    subjectKey,\n  }: {\n    approverId?: string;\n    tp: TpNode;\n    approverIndex: number;\n    saIndex: number;\n    slipAssembly: slip.Assembly;\n    assemblyKeyParams: object;\n    subjectKey: JWK.Key;\n  }) {\n    if (!tp.currentUserSharedKey.userSharedKey.mkSharedKey) {\n      throw new LrBadArgumentException(\n        `Tp ${tp.other.username} does not have mkSharedKey. Need to reshared it first.`\n      );\n    }\n\n    const sharedKey = await this.keyFactory.createKey();\n    const tpMkSharedKey = await this.keyGraph.getKey(\n      tp.currentUserSharedKey.userSharedKey.mkSharedKey.id\n    );\n    // For TP to access shared_key\n    const tpMkSharedKeyWrappedSharedKey = await this.encryptionService.encryptToString(\n      tpMkSharedKey.jwk,\n      sharedKey.toJSON(true)\n    );\n    // For subject to access shared_key\n    const subjectKeyWrappedSharedKey = await this.encryptionService.encryptToString(\n      subjectKey,\n      sharedKey.toJSON(true)\n    );\n\n    const saSlip = slipAssembly.subAssemblies[saIndex];\n    if (saSlip.index !== saIndex) {\n      // Paranoia\n      throw new LrBadLogicException(\n        'slip sub assembly index should match with array index'\n      );\n    }\n\n    // If quorum is 1, then using the same share for every member.\n    const share =\n      saSlip.threshold === 1 ? saSlip.shares[0] : saSlip.shares[approverIndex];\n\n    const partialAssemblyKey: PartialAssemblyKey = {\n      slip39: {\n        share,\n        subAssembly: {\n          quorum: saSlip.threshold,\n          size: saSlip.size,\n        },\n      },\n      assemblyKeyParams,\n    };\n\n    console.log('partialAssemblyKey', partialAssemblyKey);\n\n    return {\n      tpMkSharedKeyId: tpMkSharedKey.id,\n      tpMkSharedKeyWrappedSharedKey,\n      subjectKeyWrappedSharedKey,\n      sharedCipherData: await this.encryptionService.encryptToString(\n        sharedKey,\n        { a: '123' }\n      ),\n      sharedCipherApprovalData: '',\n      sharedCipherPartialAssemblyKey: await this.encryptionService.encryptToString(\n        sharedKey,\n        partialAssemblyKey\n      ),\n      approverId: approverId || void 0,\n      tpId: approverId ? void 0 : tp.id,\n    };\n  }\n\n  // Prepare slip39\n  private async prepareSlip39(\n    subAssemblies,\n    assemblyQuorum: number,\n    rawAssemblyKey: string\n  ): Promise<slip.Assembly> {\n    // Is there enough sub assemblies to meet quorum\n    if (subAssemblies.length < assemblyQuorum) {\n      throw new LrBadArgumentException(\n        'Not enough sub assemblies to meet quorum'\n      );\n    }\n\n    const slipAssembly = new slip.Assembly(assemblyQuorum);\n\n    subAssemblies.forEach((sa, index) => {\n      let approverCount = sa.approverTps.length;\n\n      // slip39 restricts quorum == 1 to have only 1 member. So we just share the same\n      // partial key for all sub assembly members.\n      if (sa.quorum === 1) {\n        approverCount = 1;\n      }\n      slipAssembly.addSubAssembly(\n        new slip.SubAssembly(index, sa.quorum, approverCount)\n      );\n    });\n\n    await this.slip39Service.generateShares(\n      rawAssemblyKey,\n      TpPasswordResetService.SLIP39_PASSPHRASE,\n      slipAssembly\n    );\n    return slipAssembly;\n  }\n\n  private async _createReset(\n    input: CreateTpPasswordResetInput,\n    createSlipAssembly\n  ): Promise<any> {\n    // Create subject key\n    const masterKey = await this.keyService.getCurrentMasterKey();\n    const subjectKey = await this.keyFactory.createKey();\n    const assemblyKey = await this.keyFactory.createKey();\n    const { k: rawAssemblyKey, ...assemblyKeyParams } = assemblyKey.toJSON(\n      true\n    ) as any;\n    const assemblyKeyVerifierPrk = await this.keyFactory.createPkcSignKey();\n    const wrappedAssemblyKeyVerifierPrk = await this.encryptionService.encryptToString(\n      assemblyKey,\n      assemblyKeyVerifierPrk.toJSON(true)\n    );\n\n    const masterKeyWrappedSubjectKey = await this.encryptionService.encryptToString(\n      masterKey.jwk,\n      subjectKey.toJSON(true)\n    );\n    const subjectKeyWrappedAssemblyKey = await this.encryptionService.encryptToString(\n      subjectKey,\n      assemblyKey.toJSON(true)\n    );\n\n    // Encrypt the rootKey with the assemblyKey\n    const rootKey = await this.keyService.getCurrentRootKey();\n\n    const assemblyCipherData = await this.encryptionService.encryptToString(\n      assemblyKey,\n      {\n        rootKey: rootKey.jwk.toJSON(true),\n      }\n    );\n\n    const slipAssembly = await createSlipAssembly(rawAssemblyKey);\n    // const slipAssembly = await this.prepareSlip39(input.createSubAssemblies, input.quorum, rawAssemblyKey);\n\n    const createSubAssemblies = await Promise.all(\n      input.createSubAssemblies.map(async (sa, saIndex) => {\n        const subjectCipherData = await this.encryptionService.encryptToString(\n          subjectKey,\n          {\n            name: sa.name,\n          }\n        );\n\n        return {\n          singleReject: sa.singleReject,\n          quorum: sa.quorum,\n          subjectCipherData,\n          createApprovers: await Promise.all(\n            sa.approverTps.map(async (approverTp, approverIndex) =>\n              this.prepareApprover({\n                tp: approverTp,\n                approverIndex,\n                saIndex,\n                slipAssembly,\n                assemblyKeyParams,\n                subjectKey,\n              })\n            )\n          ),\n        };\n      })\n    );\n\n    return {\n      subjectKey,\n      slipAssembly,\n      assemblyKeyParams,\n      mutationInput: {\n        assembly: {\n          singleReject: input.singleReject,\n          quorum: input.quorum,\n          masterKeyId: masterKey.id,\n          masterKeyWrappedSubjectKey,\n          subjectKeyWrappedAssemblyKey,\n          subjectCipherData: '',\n          assemblyCipherData,\n          createSubAssemblies,\n          assemblyKeyVerifierPbk: JSON.stringify(\n            assemblyKeyVerifierPrk.toJSON()\n          ),\n          wrappedAssemblyKeyVerifierPrk,\n        },\n      },\n    };\n  }\n}\n"]}
299
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tp-password-reset.service.js","sourceRoot":"/opt/atlassian/pipelines/agent/build/projects/core/src/","sources":["lib/trusted-parties/tp-password-reset.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Injector, NgZone } from '@angular/core';\nimport { KeyService } from '../cryptography/key.service';\nimport { EncryptionService } from '../cryptography/encryption.service';\nimport {\n  CreateTpPasswordResetMutation,\n  DeleteTpPasswordResetMutation,\n  TpPasswordResetQuery,\n  UpdateTpPasswordResetMutation,\n  CancelTpPasswordResetRequestMutation,\n} from './tp-password-reset.gql';\nimport { KeyGraphService } from '../cryptography/key-graph.service';\nimport * as slip from '../cryptography/slip39.service';\nimport {\n  LrBadArgumentException,\n  LrBadLogicException,\n} from '../_common/exceptions';\nimport { PartialAssemblyKey } from '../scenario/scenario.types';\nimport { JWK } from 'node-jose';\nimport { Key } from '../cryptography/cryptography.types';\nimport { KeyFactoryService } from '../cryptography/key-factory.service';\nimport { LrGraphQLService, LrMutation, LrService } from '../api/lr-graphql';\nimport { TpNode } from '../api/types';\nimport { RunOutsideAngular } from '../_common/run-outside-angular';\nimport { TP_PASSWORD_RESET_SLIP39_PASSPHRASE } from './tp-password-reset.constants';\n\nexport class CreateSubAssembliesInput {\n  name: string;\n  quorum: number;\n  singleReject: boolean;\n  approverTps: TpNode[];\n}\n\nexport class UpdateSubAssembliesInput extends CreateSubAssembliesInput {\n  id: string;\n}\n\nexport class CreateTpPasswordResetInput {\n  quorum: number;\n  singleReject: boolean;\n  createSubAssemblies: CreateSubAssembliesInput[];\n}\n\nexport class UpdateTpPasswordResetInput extends CreateTpPasswordResetInput {\n  updateSubAssemblies: UpdateSubAssembliesInput[];\n}\n\nexport interface TpAssemblyApprovers {\n  id: string;\n  tp: {\n    id: string;\n  };\n  sharedKey: Key;\n  sharedCipherData?: string;\n  sharedCipherDataClearJson?: any;\n  sharedCipherApprovalData?: string;\n  sharedCipherApprovalDataClearJson?: any;\n}\n\nexport interface TpSubAssembly {\n  id: string;\n  singleReject: boolean;\n  quorum: number;\n  subjectCipherData: string;\n  plainSubjectCipherData: any;\n  approvers: TpAssemblyApprovers[];\n}\n\nexport interface TpAssembly {\n  singleReject: boolean;\n  quorum: number;\n  subjectKey: Key;\n  assemblyKey: Key;\n  assemblyCipherData: string;\n  plainAssemblyCipherData: any;\n  subAssemblies: TpSubAssembly[];\n}\n\nexport interface TpPasswordReset {\n  id: string;\n  assembly: TpAssembly;\n  applied: boolean;\n}\n\nexport interface RequestResetResult {\n  id: string;\n  associate_reset_user_token: string;\n  reset_username: string;\n}\n\n@RunOutsideAngular({\n  ngZoneName: 'ngZone',\n})\n@Injectable({\n  providedIn: 'root',\n})\nexport class TpPasswordResetService extends LrService {\n  constructor(\n    private ngZone: NgZone,\n    private injector: Injector,\n    private keyService: KeyService,\n    private keyFactory: KeyFactoryService,\n    private encryptionService: EncryptionService,\n    private keyGraph: KeyGraphService,\n    private slip39Service: slip.Slip39Service\n  ) {\n    super(injector);\n  }\n\n  async getReset() {\n    return (\n      await this.query({\n        query: TpPasswordResetQuery,\n      })\n    ).tpPasswordReset;\n  }\n\n  createReset(input: CreateTpPasswordResetInput) {\n    return this.mutate(this.createResetMutation(input));\n  }\n\n  async createResetMutation(input: CreateTpPasswordResetInput) {\n    const { mutationInput } = await this._createReset(\n      input,\n      async (rawAssemblyKey) => {\n        return this.prepareSlip39(\n          input.createSubAssemblies,\n          input.quorum,\n          rawAssemblyKey\n        );\n      }\n    );\n\n    return new LrMutation({\n      mutation: CreateTpPasswordResetMutation,\n      variables: {\n        input: mutationInput,\n      },\n    });\n  }\n\n  deleteReset() {\n    return this.mutate(this.deleteResetMutation());\n  }\n\n  deleteResetMutation() {\n    return new LrMutation({\n      mutation: DeleteTpPasswordResetMutation,\n    });\n  }\n\n  updateReset(input: UpdateTpPasswordResetInput) {\n    return this.mutate(this.updateResetMutation(input));\n  }\n\n  async updateResetMutation(input: UpdateTpPasswordResetInput) {\n    const passwordReset = await this.getReset();\n\n    const {\n      mutationInput,\n      subjectKey,\n      slipAssembly,\n      assemblyKeyParams,\n    } = await this._createReset(input, async (rawAssemblyKey) => {\n      return this.prepareSlip39(\n        input.createSubAssemblies.concat(input.updateSubAssemblies),\n        input.quorum,\n        rawAssemblyKey\n      );\n    });\n\n    const updateSubAssemblies = await Promise.all(\n      input.updateSubAssemblies.map(async (sa, saIndex) => {\n        const subjectCipherData = await this.encryptionService.encryptToString(\n          subjectKey,\n          {\n            name: sa.name,\n          }\n        );\n\n        // Get the existing sub-assembly\n        const existingSa = passwordReset.assembly.subAssemblies.edges.find(\n          (edge) => edge.node.id === sa.id\n        ).node;\n\n        // Get approvers that do not exist yet\n        const createApprovers = [];\n        const updateApprovers = [];\n\n        sa.approverTps.forEach((tp) => {\n          const approver = existingSa.approvers.edges.find(\n            (edge) => edge.node.tp.id === tp.id\n          )?.node;\n          if (approver) {\n            updateApprovers.push({\n              tp,\n              approverId: approver.id,\n            });\n          } else {\n            createApprovers.push({\n              tp,\n            });\n          }\n        });\n\n        return {\n          subAssemblyId: sa.id,\n          singleReject: sa.singleReject,\n          quorum: sa.quorum,\n          subjectCipherData,\n          createApprovers: await Promise.all(\n            createApprovers.map(async ({ tp }, approverIndex) =>\n              this.prepareApprover({\n                tp,\n                approverIndex,\n                saIndex: saIndex + input.createSubAssemblies.length, // slipAssembly is all sub-assemblies combined\n                slipAssembly,\n                assemblyKeyParams,\n                subjectKey,\n              })\n            )\n          ),\n          updateApprovers: await Promise.all(\n            updateApprovers.map(async ({ tp, approverId }, approverIndex) =>\n              this.prepareApprover({\n                approverId,\n                tp,\n                approverIndex: approverIndex + createApprovers.length,\n                saIndex: saIndex + input.createSubAssemblies.length, // slipAssembly is all sub-assemblies combined\n                slipAssembly,\n                assemblyKeyParams,\n                subjectKey,\n              })\n            )\n          ),\n        };\n      })\n    );\n\n    return new LrMutation({\n      mutation: UpdateTpPasswordResetMutation,\n      variables: {\n        input: {\n          ...mutationInput,\n          assembly: {\n            ...mutationInput.assembly,\n            updateSubAssemblies,\n          },\n        },\n      },\n    });\n  }\n\n  cancelResetRequest() {\n    return this.mutate(this.cancelResetRequestMutation());\n  }\n\n  cancelResetRequestMutation() {\n    return new LrMutation({\n      mutation: CancelTpPasswordResetRequestMutation,\n    });\n  }\n\n  validateApprovers(approvers: TpNode[]): void {\n    // Ensure all approvers have mkSharedKey.\n    for (const tp of approvers) {\n      if (!tp.currentUserSharedKey.userSharedKey.mkSharedKey) {\n        const msg = `tp ${tp.other.username} does not have mkSharedKey`;\n        console.log(msg);\n        throw new LrBadArgumentException(msg);\n      }\n    }\n  }\n\n  private async prepareApprover({\n    approverId,\n    tp,\n    approverIndex,\n    saIndex,\n    slipAssembly,\n    assemblyKeyParams,\n    subjectKey,\n  }: {\n    approverId?: string;\n    tp: TpNode;\n    approverIndex: number;\n    saIndex: number;\n    slipAssembly: slip.Assembly;\n    assemblyKeyParams: object;\n    subjectKey: JWK.Key;\n  }) {\n    if (!tp.currentUserSharedKey.userSharedKey.mkSharedKey) {\n      throw new LrBadArgumentException(\n        `Tp ${tp.other.username} does not have mkSharedKey. Need to reshared it first.`\n      );\n    }\n\n    const sharedKey = await this.keyFactory.createKey();\n    const tpMkSharedKey = await this.keyGraph.getKey(\n      tp.currentUserSharedKey.userSharedKey.mkSharedKey.id\n    );\n    // For TP to access shared_key\n    const tpMkSharedKeyWrappedSharedKey = await this.encryptionService.encryptToString(\n      tpMkSharedKey.jwk,\n      sharedKey.toJSON(true)\n    );\n    // For subject to access shared_key\n    const subjectKeyWrappedSharedKey = await this.encryptionService.encryptToString(\n      subjectKey,\n      sharedKey.toJSON(true)\n    );\n\n    const saSlip = slipAssembly.subAssemblies[saIndex];\n    if (saSlip.index !== saIndex) {\n      // Paranoia\n      throw new LrBadLogicException(\n        'slip sub assembly index should match with array index'\n      );\n    }\n\n    // If quorum is 1, then using the same share for every member.\n    const share =\n      saSlip.threshold === 1 ? saSlip.shares[0] : saSlip.shares[approverIndex];\n\n    const partialAssemblyKey: PartialAssemblyKey = {\n      slip39: {\n        share,\n        subAssembly: {\n          quorum: saSlip.threshold,\n          size: saSlip.size,\n        },\n      },\n      assemblyKeyParams,\n    };\n\n    console.log('partialAssemblyKey', partialAssemblyKey);\n\n    return {\n      tpMkSharedKeyId: tpMkSharedKey.id,\n      tpMkSharedKeyWrappedSharedKey,\n      subjectKeyWrappedSharedKey,\n      sharedCipherData: await this.encryptionService.encryptToString(\n        sharedKey,\n        { a: '123' }\n      ),\n      sharedCipherApprovalData: '',\n      sharedCipherPartialAssemblyKey: await this.encryptionService.encryptToString(\n        sharedKey,\n        partialAssemblyKey\n      ),\n      approverId: approverId || void 0,\n      tpId: approverId ? void 0 : tp.id,\n    };\n  }\n\n  // Prepare slip39\n  private async prepareSlip39(\n    subAssemblies,\n    assemblyQuorum: number,\n    rawAssemblyKey: string\n  ): Promise<slip.Assembly> {\n    // Is there enough sub assemblies to meet quorum\n    if (subAssemblies.length < assemblyQuorum) {\n      throw new LrBadArgumentException(\n        'Not enough sub assemblies to meet quorum'\n      );\n    }\n\n    const slipAssembly = new slip.Assembly(assemblyQuorum);\n\n    subAssemblies.forEach((sa, index) => {\n      let approverCount = sa.approverTps.length;\n\n      // slip39 restricts quorum == 1 to have only 1 member. So we just share the same\n      // partial key for all sub assembly members.\n      if (sa.quorum === 1) {\n        approverCount = 1;\n      }\n      slipAssembly.addSubAssembly(\n        new slip.SubAssembly(index, sa.quorum, approverCount)\n      );\n    });\n\n    await this.slip39Service.generateShares(\n      rawAssemblyKey,\n      TP_PASSWORD_RESET_SLIP39_PASSPHRASE,\n      slipAssembly\n    );\n    return slipAssembly;\n  }\n\n  private async _createReset(\n    input: CreateTpPasswordResetInput,\n    createSlipAssembly\n  ): Promise<any> {\n    // Create subject key\n    const masterKey = await this.keyService.getCurrentMasterKey();\n    const subjectKey = await this.keyFactory.createKey();\n    const assemblyKey = await this.keyFactory.createKey();\n    const { k: rawAssemblyKey, ...assemblyKeyParams } = assemblyKey.toJSON(\n      true\n    ) as any;\n    const assemblyKeyVerifierPrk = await this.keyFactory.createPkcSignKey();\n    const wrappedAssemblyKeyVerifierPrk = await this.encryptionService.encryptToString(\n      assemblyKey,\n      assemblyKeyVerifierPrk.toJSON(true)\n    );\n\n    const masterKeyWrappedSubjectKey = await this.encryptionService.encryptToString(\n      masterKey.jwk,\n      subjectKey.toJSON(true)\n    );\n    const subjectKeyWrappedAssemblyKey = await this.encryptionService.encryptToString(\n      subjectKey,\n      assemblyKey.toJSON(true)\n    );\n\n    // Encrypt the rootKey with the assemblyKey\n    const rootKey = await this.keyService.getCurrentRootKey();\n\n    const assemblyCipherData = await this.encryptionService.encryptToString(\n      assemblyKey,\n      {\n        rootKey: rootKey.jwk.toJSON(true),\n      }\n    );\n\n    const slipAssembly = await createSlipAssembly(rawAssemblyKey);\n    // const slipAssembly = await this.prepareSlip39(input.createSubAssemblies, input.quorum, rawAssemblyKey);\n\n    const createSubAssemblies = await Promise.all(\n      input.createSubAssemblies.map(async (sa, saIndex) => {\n        const subjectCipherData = await this.encryptionService.encryptToString(\n          subjectKey,\n          {\n            name: sa.name,\n          }\n        );\n\n        return {\n          singleReject: sa.singleReject,\n          quorum: sa.quorum,\n          subjectCipherData,\n          createApprovers: await Promise.all(\n            sa.approverTps.map(async (approverTp, approverIndex) =>\n              this.prepareApprover({\n                tp: approverTp,\n                approverIndex,\n                saIndex,\n                slipAssembly,\n                assemblyKeyParams,\n                subjectKey,\n              })\n            )\n          ),\n        };\n      })\n    );\n\n    return {\n      subjectKey,\n      slipAssembly,\n      assemblyKeyParams,\n      mutationInput: {\n        assembly: {\n          singleReject: input.singleReject,\n          quorum: input.quorum,\n          masterKeyId: masterKey.id,\n          masterKeyWrappedSubjectKey,\n          subjectKeyWrappedAssemblyKey,\n          subjectCipherData: '',\n          assemblyCipherData,\n          createSubAssemblies,\n          assemblyKeyVerifierPbk: JSON.stringify(\n            assemblyKeyVerifierPrk.toJSON()\n          ),\n          wrappedAssemblyKeyVerifierPrk,\n        },\n      },\n    };\n  }\n}\n"]}