@lifeready/core 1.0.10 → 1.0.12
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 +7390 -8456
- package/bundles/lifeready-core.umd.js.map +1 -1
- package/bundles/lifeready-core.umd.min.js +2 -2
- package/bundles/lifeready-core.umd.min.js.map +1 -1
- package/esm2015/lib/_common/utils.js +9 -1
- package/esm2015/lib/api/lock.service.js +10 -10
- package/esm2015/lib/api/lr-graphql/lr-merged-mutation.js +1 -1
- package/esm2015/lib/api/query-processor/query-processor.service.js +71 -1
- package/esm2015/lib/api/types/lr-graphql.types.js +31 -1
- package/esm2015/lib/auth/life-ready-auth.service.js +12 -24
- package/esm2015/lib/cryptography/encryption.service.js +3 -3
- package/esm2015/lib/cryptography/key-graph.service.js +24 -5
- package/esm2015/lib/items2/item2.gql.js +139 -0
- package/esm2015/lib/items2/item2.service.js +498 -0
- package/esm2015/lib/items2/item2.types.js +1 -0
- package/esm2015/lib/scenario/scenario.constants.js +2 -0
- package/esm2015/lib/scenario/scenario.controller.js +34 -0
- package/esm2015/lib/scenario/scenario.gql.js +35 -331
- package/esm2015/lib/scenario/scenario.gql.private.js +198 -0
- package/esm2015/lib/scenario/scenario.service.js +420 -493
- package/esm2015/lib/scenario/scenario.types.js +1 -64
- package/esm2015/lib/trusted-parties/tp-assembly.gql.private.js +22 -0
- package/esm2015/lib/trusted-parties/tp-assembly.js +362 -0
- package/esm2015/lib/trusted-parties/tp-assembly.types.js +1 -0
- package/esm2015/lib/trusted-parties/tp-password-reset-request.service.js +4 -3
- package/esm2015/lib/trusted-parties/tp-password-reset.controller.js +34 -0
- package/esm2015/lib/trusted-parties/tp-password-reset.gql.js +5 -1
- package/esm2015/lib/trusted-parties/tp-password-reset.service.js +36 -240
- package/esm2015/lib/trusted-parties/trusted-party2.service.js +3 -3
- package/esm2015/lifeready-core.js +6 -3
- package/esm2015/public-api.js +6 -15
- package/fesm2015/lifeready-core.js +6127 -6909
- package/fesm2015/lifeready-core.js.map +1 -1
- package/lib/_common/utils.d.ts +6 -0
- package/lib/api/lock.service.d.ts +12 -3
- package/lib/api/lr-graphql/lr-merged-mutation.d.ts +1 -0
- package/lib/api/query-processor/query-processor.service.d.ts +1 -1
- package/lib/api/types/lr-graphql.types.d.ts +107 -2
- package/lib/auth/life-ready-auth.service.d.ts +3 -1
- package/lib/cryptography/key-graph.service.d.ts +9 -1
- package/lib/{api → items2}/item2.gql.d.ts +28 -1
- package/lib/items2/item2.service.d.ts +203 -0
- package/lib/items2/item2.types.d.ts +70 -0
- package/lib/scenario/scenario.constants.d.ts +1 -0
- package/lib/scenario/scenario.controller.d.ts +10 -0
- package/lib/scenario/scenario.gql.d.ts +52 -24
- package/lib/scenario/scenario.gql.private.d.ts +16 -0
- package/lib/scenario/scenario.service.d.ts +229 -54
- package/lib/scenario/scenario.types.d.ts +47 -214
- package/lib/trusted-parties/tp-assembly.d.ts +177 -0
- package/lib/trusted-parties/tp-assembly.gql.private.d.ts +5 -0
- package/lib/trusted-parties/tp-assembly.types.d.ts +38 -0
- package/lib/trusted-parties/tp-password-reset-request.service.d.ts +3 -3
- package/lib/trusted-parties/tp-password-reset.controller.d.ts +10 -0
- package/lib/trusted-parties/tp-password-reset.gql.d.ts +5 -0
- package/lib/trusted-parties/tp-password-reset.service.d.ts +99 -41
- package/lib/trusted-parties/trusted-party2.service.d.ts +1 -1
- package/lifeready-core.d.ts +5 -2
- package/lifeready-core.metadata.json +1 -1
- package/package.json +1 -1
- package/public-api.d.ts +5 -14
- package/esm2015/lib/api/item2.gql.js +0 -110
- package/esm2015/lib/api/item2.service.js +0 -311
- package/esm2015/lib/scenario/approvals/scenario-approval.gql.js +0 -105
- package/esm2015/lib/scenario/approvals/scenario-approval.types.js +0 -1
- package/esm2015/lib/scenario/approvals/scenario-approver.service.js +0 -300
- package/esm2015/lib/scenario/claimants/scenario-claimant.gql.js +0 -52
- package/esm2015/lib/scenario/claimants/scenario-claimant.service.js +0 -97
- package/esm2015/lib/scenario/claimants/scenario-claimant.types.js +0 -1
- package/esm2015/lib/scenario/receivers/scenario-receiver.gql.js +0 -150
- package/esm2015/lib/scenario/receivers/scenario-receiver.service.js +0 -229
- package/esm2015/lib/scenario/receivers/scenario-receiver.types.js +0 -1
- package/esm2015/lib/scenario/scenario-setup.service.js +0 -269
- package/lib/api/item2.service.d.ts +0 -177
- package/lib/scenario/approvals/scenario-approval.gql.d.ts +0 -7
- package/lib/scenario/approvals/scenario-approval.types.d.ts +0 -63
- package/lib/scenario/approvals/scenario-approver.service.d.ts +0 -32
- package/lib/scenario/claimants/scenario-claimant.gql.d.ts +0 -5
- package/lib/scenario/claimants/scenario-claimant.service.d.ts +0 -17
- package/lib/scenario/claimants/scenario-claimant.types.d.ts +0 -18
- package/lib/scenario/receivers/scenario-receiver.gql.d.ts +0 -8
- package/lib/scenario/receivers/scenario-receiver.service.d.ts +0 -30
- package/lib/scenario/receivers/scenario-receiver.types.d.ts +0 -54
- package/lib/scenario/scenario-setup.service.d.ts +0 -22
|
@@ -54,9 +54,10 @@ let TpPasswordResetRequestService = class TpPasswordResetRequestService extends
|
|
|
54
54
|
})));
|
|
55
55
|
});
|
|
56
56
|
}
|
|
57
|
-
// ?? TODO The return from this should not be any.
|
|
58
57
|
approveRequest(sharedResetId, pbkFingerPrint) {
|
|
59
|
-
return
|
|
58
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
59
|
+
return this.lrGraphQL.lrMutate(yield this.approveRequestMutation(sharedResetId, pbkFingerPrint));
|
|
60
|
+
});
|
|
60
61
|
}
|
|
61
62
|
approveRequestMutation(sharedResetId, pbkFingerPrint) {
|
|
62
63
|
return __awaiter(this, void 0, void 0, function* () {
|
|
@@ -109,4 +110,4 @@ TpPasswordResetRequestService = __decorate([
|
|
|
109
110
|
})
|
|
110
111
|
], TpPasswordResetRequestService);
|
|
111
112
|
export { TpPasswordResetRequestService };
|
|
112
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tp-password-reset-request.service.js","sourceRoot":"/opt/atlassian/pipelines/agent/build/projects/core/src/","sources":["lib/trusted-parties/tp-password-reset-request.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Injector, NgZone } from '@angular/core';\nimport { JWK } from 'node-jose';\nimport {\n  LrGraphQLService,\n  LrMergedMutation,\n  LrMutation,\n  LrMutationBase,\n  LrService,\n} from '../api/lr-graphql';\nimport { TpAssemblyState, TpClaimApproverState } from '../api/types';\nimport { EncryptionService } from '../cryptography/encryption.service';\nimport { LrBadStateException } from '../_common/exceptions';\nimport { RunOutsideAngular } from '../_common/run-outside-angular';\nimport {\n  ApproveTpPasswordResetRequestMutation,\n  RejectTpPasswordResetRequestMutation,\n  SharedTpPasswordResetQuery,\n  SharedTpPasswordResetsQuery,\n} from './tp-password-reset.gql';\n\n@RunOutsideAngular({\n  ngZoneName: 'ngZone',\n})\n@Injectable({\n  providedIn: 'root',\n})\nexport class TpPasswordResetRequestService extends LrService {\n  constructor(\n    private ngZone: NgZone,\n    private injector: Injector,\n    private encryptionService: EncryptionService\n  ) {\n    super(injector);\n  }\n\n  async getSharedResets() {\n    return (\n      await this.query({\n        query: SharedTpPasswordResetsQuery,\n      })\n    ).sharedTpPasswordResets;\n  }\n\n  async getSharedReset(id) {\n    return (\n      await this.query({\n        query: SharedTpPasswordResetQuery,\n        variables: {\n          id,\n        },\n      })\n    ).sharedTpPasswordReset;\n  }\n\n  private activeRequestOrRaise(sharedReset): void {\n    const state = sharedReset.sharedRequest.claim.state;\n    if (state !== TpAssemblyState.CLAIMED) {\n      throw new LrBadStateException(`Claim is already in ${state} state.`);\n    }\n  }\n\n  rejectRequest(sharedResetId: string) {\n    return this.mutate(this.rejectRequestMutation(sharedResetId));\n  }\n\n  async rejectRequestMutation(sharedResetId: string) {\n    const sharedReset = await this.getSharedReset(sharedResetId);\n\n    this.activeRequestOrRaise(sharedReset);\n\n    return LrMergedMutation.create(\n      sharedReset.sharedRequest.claim.asClaimApprovers.edges\n        .filter((edge) => edge.node.state === TpClaimApproverState.CLAIMED)\n        .map(\n          (edge) =>\n            new LrMutation({\n              mutation: RejectTpPasswordResetRequestMutation,\n              variables: { input: { claimApproverId: edge.node.id } },\n            })\n        )\n    );\n  }\n\n  // ?? TODO The return from this should not be any.\n  approveRequest(sharedResetId: string, pbkFingerPrint?: string) {\n    return this.mutate(\n      this.approveRequestMutation(sharedResetId, pbkFingerPrint)\n    );\n  }\n\n  async approveRequestMutation(sharedResetId: string, pbkFingerPrint?: string) {\n    const sharedReset = await this.getSharedReset(sharedResetId);\n\n    this.activeRequestOrRaise(sharedReset);\n\n    const pbk = await JWK.asKey(JSON.parse(sharedReset.sharedRequest.pxk.pbk));\n    console.log(pbk.toJSON());\n\n    // TODO <AZ> Verify pbk against pbkFingerPrint\n\n    const claimApprovers = sharedReset.sharedRequest.claim.asClaimApprovers.edges.filter(\n      (edge) => edge.node.state === TpClaimApproverState.CLAIMED\n    );\n\n    // A single approver may belong to multiple sub-assemblies. We approve them all here in a single\n    // transaction.\n    return LrMergedMutation.create(\n      await Promise.all(\n        claimApprovers.map(async (approverEdge) => {\n          const ca = approverEdge.node;\n          const input = {\n            claimApproverId: ca.id,\n            receiverApprovals: await Promise.all(\n              ca.receiverApprovals.edges.map(async (receiverEdge) => {\n                const ra = receiverEdge.node;\n                return {\n                  receiverApprovalId: ra.id,\n                  receiverCipher: '',\n                  receiverCipherPartialAssemblyKey: await this.encryptionService.encryptToString(\n                    pbk,\n                    ca.sharedCipherPartialAssemblyKeyClearJson\n                  ),\n                };\n              })\n            ),\n          };\n\n          console.log(input);\n\n          return new LrMutation({\n            mutation: ApproveTpPasswordResetRequestMutation,\n            variables: {\n              input,\n            },\n          });\n        })\n      )\n    );\n  }\n}\n"]}
|
|
113
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tp-password-reset-request.service.js","sourceRoot":"/opt/atlassian/pipelines/agent/build/projects/core/src/","sources":["lib/trusted-parties/tp-password-reset-request.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Injector, NgZone } from '@angular/core';\nimport { JWK } from 'node-jose';\nimport {\n  LrGraphQLService,\n  LrMergedMutation,\n  LrMutation,\n  LrMutationBase,\n  LrService,\n} from '../api/lr-graphql';\nimport { TpAssemblyState, TpClaimApproverState } from '../api/types';\nimport { EncryptionService } from '../cryptography/encryption.service';\nimport { LrBadStateException } from '../_common/exceptions';\nimport { RunOutsideAngular } from '../_common/run-outside-angular';\nimport {\n  ApproveTpPasswordResetRequestMutation,\n  RejectTpPasswordResetRequestMutation,\n  SharedTpPasswordResetQuery,\n  SharedTpPasswordResetsQuery,\n} from './tp-password-reset.gql';\n\n@RunOutsideAngular({\n  ngZoneName: 'ngZone',\n})\n@Injectable({\n  providedIn: 'root',\n})\nexport class TpPasswordResetRequestService extends LrService {\n  constructor(\n    private ngZone: NgZone,\n    private injector: Injector,\n    private encryptionService: EncryptionService\n  ) {\n    super(injector);\n  }\n\n  async getSharedResets() {\n    return (\n      await this.query({\n        query: SharedTpPasswordResetsQuery,\n      })\n    ).sharedTpPasswordResets;\n  }\n\n  async getSharedReset(id) {\n    return (\n      await this.query({\n        query: SharedTpPasswordResetQuery,\n        variables: {\n          id,\n        },\n      })\n    ).sharedTpPasswordReset;\n  }\n\n  private activeRequestOrRaise(sharedReset): void {\n    const state = sharedReset.sharedRequest.claim.state;\n    if (state !== TpAssemblyState.CLAIMED) {\n      throw new LrBadStateException(`Claim is already in ${state} state.`);\n    }\n  }\n\n  rejectRequest(sharedResetId: string) {\n    return this.mutate(this.rejectRequestMutation(sharedResetId));\n  }\n\n  async rejectRequestMutation(sharedResetId: string) {\n    const sharedReset = await this.getSharedReset(sharedResetId);\n\n    this.activeRequestOrRaise(sharedReset);\n\n    return LrMergedMutation.create(\n      sharedReset.sharedRequest.claim.asClaimApprovers.edges\n        .filter((edge) => edge.node.state === TpClaimApproverState.CLAIMED)\n        .map(\n          (edge) =>\n            new LrMutation({\n              mutation: RejectTpPasswordResetRequestMutation,\n              variables: { input: { claimApproverId: edge.node.id } },\n            })\n        )\n    );\n  }\n\n  async approveRequest(sharedResetId: string, pbkFingerPrint?: string) {\n    return this.lrGraphQL.lrMutate(\n      await this.approveRequestMutation(sharedResetId, pbkFingerPrint)\n    );\n  }\n\n  async approveRequestMutation(sharedResetId: string, pbkFingerPrint?: string) {\n    const sharedReset = await this.getSharedReset(sharedResetId);\n\n    this.activeRequestOrRaise(sharedReset);\n\n    const pbk = await JWK.asKey(JSON.parse(sharedReset.sharedRequest.pxk.pbk));\n    console.log(pbk.toJSON());\n\n    // TODO <AZ> Verify pbk against pbkFingerPrint\n\n    const claimApprovers = sharedReset.sharedRequest.claim.asClaimApprovers.edges.filter(\n      (edge) => edge.node.state === TpClaimApproverState.CLAIMED\n    );\n\n    // A single approver may belong to multiple sub-assemblies. We approve them all here in a single\n    // transaction.\n    return LrMergedMutation.create(\n      await Promise.all(\n        claimApprovers.map(async (approverEdge) => {\n          const ca = approverEdge.node;\n          const input = {\n            claimApproverId: ca.id,\n            receiverApprovals: await Promise.all(\n              ca.receiverApprovals.edges.map(async (receiverEdge) => {\n                const ra = receiverEdge.node;\n                return {\n                  receiverApprovalId: ra.id,\n                  receiverCipher: '',\n                  receiverCipherPartialAssemblyKey: await this.encryptionService.encryptToString(\n                    pbk,\n                    ca.sharedCipherPartialAssemblyKeyClearJson\n                  ),\n                };\n              })\n            ),\n          };\n\n          console.log(input);\n\n          return new LrMutation({\n            mutation: ApproveTpPasswordResetRequestMutation,\n            variables: {\n              input,\n            },\n          });\n        })\n      )\n    );\n  }\n}\n"]}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { Injectable, Injector, NgZone } from '@angular/core';
|
|
3
|
+
import { RunOutsideAngular } from '../_common/run-outside-angular';
|
|
4
|
+
import { TpAssemblyController } from './tp-assembly';
|
|
5
|
+
import { TP_PASSWORD_RESET_SLIP39_PASSPHRASE } from './tp-password-reset.constants';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
let TpPasswordResetAssemblyController = class TpPasswordResetAssemblyController extends TpAssemblyController {
|
|
8
|
+
constructor(ngZone, injector) {
|
|
9
|
+
super(injector);
|
|
10
|
+
this.ngZone = ngZone;
|
|
11
|
+
this.injector = injector;
|
|
12
|
+
this.slip39Passphrase = TP_PASSWORD_RESET_SLIP39_PASSPHRASE;
|
|
13
|
+
}
|
|
14
|
+
getTpWrappingKeyId(tp) {
|
|
15
|
+
return tp.currentUserSharedKey.userSharedKey.mkSharedKey.id;
|
|
16
|
+
}
|
|
17
|
+
};
|
|
18
|
+
TpPasswordResetAssemblyController.ɵprov = i0.ɵɵdefineInjectable({ factory: function TpPasswordResetAssemblyController_Factory() { return new TpPasswordResetAssemblyController(i0.ɵɵinject(i0.NgZone), i0.ɵɵinject(i0.INJECTOR)); }, token: TpPasswordResetAssemblyController, providedIn: "root" });
|
|
19
|
+
TpPasswordResetAssemblyController.decorators = [
|
|
20
|
+
{ type: Injectable, args: [{
|
|
21
|
+
providedIn: 'root',
|
|
22
|
+
},] }
|
|
23
|
+
];
|
|
24
|
+
TpPasswordResetAssemblyController.ctorParameters = () => [
|
|
25
|
+
{ type: NgZone },
|
|
26
|
+
{ type: Injector }
|
|
27
|
+
];
|
|
28
|
+
TpPasswordResetAssemblyController = __decorate([
|
|
29
|
+
RunOutsideAngular({
|
|
30
|
+
ngZoneName: 'ngZone',
|
|
31
|
+
})
|
|
32
|
+
], TpPasswordResetAssemblyController);
|
|
33
|
+
export { TpPasswordResetAssemblyController };
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHAtcGFzc3dvcmQtcmVzZXQuY29udHJvbGxlci5qcyIsInNvdXJjZVJvb3QiOiIvb3B0L2F0bGFzc2lhbi9waXBlbGluZXMvYWdlbnQvYnVpbGQvcHJvamVjdHMvY29yZS9zcmMvIiwic291cmNlcyI6WyJsaWIvdHJ1c3RlZC1wYXJ0aWVzL3RwLXBhc3N3b3JkLXJlc2V0LmNvbnRyb2xsZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUU3RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNuRSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDckQsT0FBTyxFQUFFLG1DQUFtQyxFQUFFLE1BQU0sK0JBQStCLENBQUM7O0lBUXZFLGlDQUFpQyxTQUFqQyxpQ0FBa0MsU0FBUSxvQkFBb0I7SUFHekUsWUFBb0IsTUFBYyxFQUFVLFFBQWtCO1FBQzVELEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQztRQURFLFdBQU0sR0FBTixNQUFNLENBQVE7UUFBVSxhQUFRLEdBQVIsUUFBUSxDQUFVO1FBRjlELHFCQUFnQixHQUFHLG1DQUFtQyxDQUFDO0lBSXZELENBQUM7SUFFRCxrQkFBa0IsQ0FBQyxFQUFVO1FBQzNCLE9BQU8sRUFBRSxDQUFDLG9CQUFvQixDQUFDLGFBQWEsQ0FBQyxXQUFXLENBQUMsRUFBRSxDQUFDO0lBQzlELENBQUM7Q0FDRixDQUFBOzs7WUFiQSxVQUFVLFNBQUM7Z0JBQ1YsVUFBVSxFQUFFLE1BQU07YUFDbkI7OztZQVg4QixNQUFNO1lBQWhCLFFBQVE7O0FBWWhCLGlDQUFpQztJQU43QyxpQkFBaUIsQ0FBQztRQUNqQixVQUFVLEVBQUUsUUFBUTtLQUNyQixDQUFDO0dBSVcsaUNBQWlDLENBVTdDO1NBVlksaUNBQWlDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSwgSW5qZWN0b3IsIE5nWm9uZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVHBOb2RlIH0gZnJvbSAnLi4vYXBpL3R5cGVzJztcbmltcG9ydCB7IFJ1bk91dHNpZGVBbmd1bGFyIH0gZnJvbSAnLi4vX2NvbW1vbi9ydW4tb3V0c2lkZS1hbmd1bGFyJztcbmltcG9ydCB7IFRwQXNzZW1ibHlDb250cm9sbGVyIH0gZnJvbSAnLi90cC1hc3NlbWJseSc7XG5pbXBvcnQgeyBUUF9QQVNTV09SRF9SRVNFVF9TTElQMzlfUEFTU1BIUkFTRSB9IGZyb20gJy4vdHAtcGFzc3dvcmQtcmVzZXQuY29uc3RhbnRzJztcblxuQFJ1bk91dHNpZGVBbmd1bGFyKHtcbiAgbmdab25lTmFtZTogJ25nWm9uZScsXG59KVxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCcsXG59KVxuZXhwb3J0IGNsYXNzIFRwUGFzc3dvcmRSZXNldEFzc2VtYmx5Q29udHJvbGxlciBleHRlbmRzIFRwQXNzZW1ibHlDb250cm9sbGVyIHtcbiAgc2xpcDM5UGFzc3BocmFzZSA9IFRQX1BBU1NXT1JEX1JFU0VUX1NMSVAzOV9QQVNTUEhSQVNFO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgbmdab25lOiBOZ1pvbmUsIHByaXZhdGUgaW5qZWN0b3I6IEluamVjdG9yKSB7XG4gICAgc3VwZXIoaW5qZWN0b3IpO1xuICB9XG5cbiAgZ2V0VHBXcmFwcGluZ0tleUlkKHRwOiBUcE5vZGUpIHtcbiAgICByZXR1cm4gdHAuY3VycmVudFVzZXJTaGFyZWRLZXkudXNlclNoYXJlZEtleS5ta1NoYXJlZEtleS5pZDtcbiAgfVxufVxuIl19
|
|
@@ -173,6 +173,7 @@ query TpPasswordResetQuery {
|
|
|
173
173
|
assembly {
|
|
174
174
|
singleReject
|
|
175
175
|
quorum
|
|
176
|
+
subjectCipherData
|
|
176
177
|
subjectKey {
|
|
177
178
|
id
|
|
178
179
|
}
|
|
@@ -187,6 +188,9 @@ query TpPasswordResetQuery {
|
|
|
187
188
|
singleReject
|
|
188
189
|
quorum
|
|
189
190
|
subjectCipherData
|
|
191
|
+
subjectKey {
|
|
192
|
+
id
|
|
193
|
+
}
|
|
190
194
|
approvers {
|
|
191
195
|
edges {
|
|
192
196
|
node {
|
|
@@ -229,4 +233,4 @@ mutation UpdateTpPasswordResetMutation($input: UpdateTpPasswordResetInput!) {
|
|
|
229
233
|
}
|
|
230
234
|
}
|
|
231
235
|
}`;
|
|
232
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tp-password-reset.gql.js","sourceRoot":"/opt/atlassian/pipelines/agent/build/projects/core/src/","sources":["lib/trusted-parties/tp-password-reset.gql.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AA+D1C,MAAM,6BAA6B,GAAG,QAAQ,CAAqC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAqDjF,CAAC;AASH,MAAM,CAAC,MAAM,2BAA2B,GAAG,QAAQ,CAAmC;;;;;;;;;;EAUpF,6BAA6B;CAC9B,CAAC;AAKF,MAAM,CAAC,MAAM,0BAA0B,GAAG,QAAQ,CAAkC;;;;;;EAMlF,6BAA6B;CAC9B,CAAC;AAOF,MAAM,CAAC,MAAM,oCAAoC,GAAG,QAAQ,CAA4C;;;;;EAKtG,CAAC;AAOH,MAAM,CAAC,MAAM,oCAAoC,GAAG,QAAQ,CAA4C;;;;;;;EAOtG,CAAC;AAOH,MAAM,CAAC,MAAM,yCAAyC,GAAG,QAAQ,CAAiD;;;;;;;EAOhH,CAAC;AAOH,MAAM,CAAC,MAAM,sCAAsC,GAAG,QAAQ,CAA8C;;;;;;;EAO1G,CAAC;AASH,MAAM,CAAC,MAAM,qCAAqC,GAAG,QAAQ,CAA6C;;;;;;;;;EASxG,CAAC;AASH,MAAM,CAAC,MAAM,oCAAoC,GAAG,QAAQ,CAA4C;;;;;;;;;EAStG,CAAC;AA2CH,MAAM,CAAC,MAAM,wBAAwB,GAAG,QAAQ,CAAgC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAyC9E,CAAC;AA4CH,MAAM,CAAC,MAAM,oBAAoB,GAAG,QAAQ,CAA4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAyCtE,CAAC;AASH,MAAM,CAAC,MAAM,6BAA6B,GAAG,QAAQ,CAAqC;;;;;;;EAOxF,CAAC;AAOH,MAAM,CAAC,MAAM,6BAA6B,GAAG,QAAQ,CAAqC;;;;;EAKxF,CAAC;AASH,MAAM,CAAC,MAAM,6BAA6B,GAAG,QAAQ,CAAqC;;;;;;;EAOxF,CAAC","sourcesContent":["import { GenericScalar, ID } from '../api/types';\nimport { gqlTyped } from '../_common/ast';\nimport {\n  TpClaimState,\n  TpClaimApproverState,\n} from '../api/types/lr-graphql.types';\nimport { DateTime } from '../api/types/graphql.types';\n\nexport interface SharedTpPasswordResetFragmentResult {\n  id: ID;\n  tp: {\n    id: ID;\n    other: {\n      username: string;\n    };\n  };\n  assembly: {\n    asApprovers: {\n      edges: {\n        node: {\n          id: ID;\n          sharedKey: {\n            id: ID;\n          };\n          sharedCipherData: string;\n          sharedCipherDataClearJson: any;\n        };\n      }[];\n    };\n  };\n  sharedRequest: {\n    id: ID;\n    pxk: {\n      id: ID;\n      pbk: string;\n    };\n    claim: {\n      id: ID;\n      state: TpClaimState;\n      asClaimApprovers: {\n        edges: {\n          node: {\n            id: ID;\n            state: TpClaimApproverState;\n            sharedKey: {\n              id: ID;\n            };\n            sharedCipherApprovalData: string;\n            sharedCipherApprovalDataClearJson: any;\n            sharedCipherPartialAssemblyKey: string;\n            sharedCipherPartialAssemblyKeyClearJson: any;\n            receiverApprovals: {\n              edges: {\n                node: {\n                  id: ID;\n                };\n              }[];\n            };\n          };\n        }[];\n      };\n    };\n  };\n}\nconst SharedTpPasswordResetFragment = gqlTyped<SharedTpPasswordResetFragmentResult>`\nfragment SharedTpPasswordResetFragment on SharedTpPasswordResetNode {\n  id\n  tp {\n    id\n    other {\n      username\n    }\n  }\n  assembly {\n    asApprovers {\n      edges {\n        node {\n          id\n          sharedKey {\n            id\n          }\n          sharedCipherData\n        }\n      }\n    }\n  }\n  sharedRequest {\n    id\n    pxk {\n      id\n      pbk\n    }\n    claim {\n      id\n      state\n      asClaimApprovers {\n        edges {\n          node {\n            id\n            state\n            sharedKey {\n              id\n            }\n            sharedCipherApprovalData\n            sharedCipherPartialAssemblyKey\n            receiverApprovals {\n              edges {\n                node {\n                  id\n                }\n              }\n            }\n          }\n        }\n      }\n    }\n  }\n}`;\n\nexport interface SharedTpPasswordResetsQueryResult {\n  sharedTpPasswordResets: {\n    edges: {\n      node: SharedTpPasswordResetFragmentResult;\n    }[];\n  };\n}\nexport const SharedTpPasswordResetsQuery = gqlTyped<SharedTpPasswordResetsQueryResult>`\nquery SharedTpPasswordResetsQuery {\n  sharedTpPasswordResets {\n    edges {\n      node {\n        ...SharedTpPasswordResetFragment\n      }\n    }\n  }\n}\n${SharedTpPasswordResetFragment}\n`;\n\nexport interface SharedTpPasswordResetQueryResult {\n  sharedTpPasswordReset: SharedTpPasswordResetFragmentResult;\n}\nexport const SharedTpPasswordResetQuery = gqlTyped<SharedTpPasswordResetQueryResult>`\nquery SharedTpPasswordResetQuery($id: LrRelayIdInput!) {\n  sharedTpPasswordReset(id: $id) {\n    ...SharedTpPasswordResetFragment\n  }\n}\n${SharedTpPasswordResetFragment}\n`;\n\nexport interface CancelTpPasswordResetRequestMutationResult {\n  cancelTpPasswordResetRequest: {\n    id: ID;\n  };\n}\nexport const CancelTpPasswordResetRequestMutation = gqlTyped<CancelTpPasswordResetRequestMutationResult>`\nmutation CancelTpPasswordResetRequestMutation {\n  cancelTpPasswordResetRequest(input: {}) {\n    id\n  }\n}`;\n\nexport interface CreateTpAssemblyKeyChallengeMutationResult {\n  createTpAssemblyKeyChallenge: {\n    challenge: any;\n  };\n}\nexport const CreateTpAssemblyKeyChallengeMutation = gqlTyped<CreateTpAssemblyKeyChallengeMutationResult>`\nmutation CreateTpAssemblyKeyChallengeMutation(\n  $input: CreateTpAssemblyKeyChallengeInput!\n) {\n  createTpAssemblyKeyChallenge(input: $input) {\n    challenge\n  }\n}`;\n\nexport interface PreCompleteTpPasswordResetRequestMutationResult {\n  preCompleteTpPasswordResetRequest: {\n    idpPassword: string;\n  };\n}\nexport const PreCompleteTpPasswordResetRequestMutation = gqlTyped<PreCompleteTpPasswordResetRequestMutationResult>`\nmutation PreCompleteTpPasswordResetRequestMutation(\n  $input: PreCompleteTpPasswordResetRequestInput!\n) {\n  preCompleteTpPasswordResetRequest(input: $input) {\n    idpPassword\n  }\n}`;\n\nexport interface CompleteTpPasswordResetRequestMutationResult {\n  completeTpPasswordResetRequest: {\n    id: ID;\n  };\n}\nexport const CompleteTpPasswordResetRequestMutation = gqlTyped<CompleteTpPasswordResetRequestMutationResult>`\nmutation CompleteTpPasswordResetRequestMutation(\n  $input: CompleteTpPasswordResetRequestInput!\n) {\n  completeTpPasswordResetRequest(input: $input) {\n    id\n  }\n}`;\n\nexport interface ApproveTpPasswordResetRequestMutationResult {\n  approveTpPasswordResetRequest: {\n    claimApprover: {\n      id: ID;\n    };\n  };\n}\nexport const ApproveTpPasswordResetRequestMutation = gqlTyped<ApproveTpPasswordResetRequestMutationResult>`\nmutation ApproveTpPasswordResetRequestMutation(\n  $input: ApproveTpPasswordResetRequestInput!\n) {\n  approveTpPasswordResetRequest(input: $input) {\n    claimApprover {\n      id\n    }\n  }\n}`;\n\nexport interface RejectTpPasswordResetRequestMutationResult {\n  rejectTpPasswordResetRequest: {\n    claimApprover: {\n      id: ID;\n    };\n  };\n}\nexport const RejectTpPasswordResetRequestMutation = gqlTyped<RejectTpPasswordResetRequestMutationResult>`\nmutation RejectTpPasswordResetRequestMutation(\n  $input: RejectTpPasswordResetRequestInput!\n) {\n  rejectTpPasswordResetRequest(input: $input) {\n    claimApprover {\n      id\n    }\n  }\n}`;\n\nexport interface TpPasswordResetUserQueryResult {\n  tpPasswordResetUser: {\n    username: string;\n    resetUsername: string;\n    state: TpClaimState;\n    passKey: {\n      id: ID;\n      passKeyParams: GenericScalar;\n      passIdpParams: GenericScalar;\n    };\n    masterKey: {\n      id: ID;\n    };\n    pxk: {\n      id: ID;\n    };\n    sessionEncryptionKey: string;\n    assembly: {\n      singleReject: boolean;\n      quorum: number;\n      subAssemblies: {\n        singleReject: boolean;\n        quorum: number;\n        approvers: {\n          name: string;\n          email: string;\n          state: TpClaimApproverState;\n        }[];\n      }[];\n    };\n    approvals: {\n      id: ID;\n      modified: DateTime;\n      approverEmail: string;\n      receiverCipher: string;\n      receiverCipherPartialAssemblyKey: string;\n    }[];\n    assemblyCipherData: string;\n    wrappedAssemblyKeyVerifierPrk: string;\n  };\n}\nexport const TpPasswordResetUserQuery = gqlTyped<TpPasswordResetUserQueryResult>`\nquery TpPasswordResetUserQuery {\n  tpPasswordResetUser {\n    username\n    resetUsername\n    state\n    passKey {\n      id\n      passKeyParams\n      passIdpParams\n    }\n    masterKey {\n      id\n    }\n    pxk {\n      id\n    }\n    sessionEncryptionKey\n    assembly {\n      singleReject\n      quorum\n      subAssemblies {\n        singleReject\n        quorum\n        approvers {\n          name\n          email\n          state\n        }\n      }\n    }\n    approvals {\n      id\n      modified\n      approverEmail\n      receiverCipher\n      receiverCipherPartialAssemblyKey\n    }\n    assemblyCipherData\n    wrappedAssemblyKeyVerifierPrk\n  }\n}`;\n\nexport interface TpPasswordResetQueryResult {\n  tpPasswordReset: {\n    id: ID;\n    applied: boolean;\n    assembly: {\n      singleReject: boolean;\n      quorum: number;\n      subjectKey: {\n        id: ID;\n      };\n      assemblyKey: {\n        id: ID;\n      };\n      assemblyCipherData: string;\n      subAssemblies: {\n        edges: {\n          node: {\n            id: ID;\n            singleReject: boolean;\n            quorum: number;\n            subjectCipherData: string;\n            subjectCipherDataClearJson: any;\n            approvers: {\n              edges: {\n                node: {\n                  id: ID;\n                  tp: {\n                    id: ID;\n                  };\n                  sharedKey: {\n                    id: ID;\n                  };\n                  sharedCipherData: string;\n                };\n              }[];\n            };\n          };\n        }[];\n      };\n    };\n  };\n}\nexport const TpPasswordResetQuery = gqlTyped<TpPasswordResetQueryResult>`\nquery TpPasswordResetQuery {\n  tpPasswordReset {\n    id\n    applied\n    assembly {\n      singleReject\n      quorum\n      subjectKey {\n        id\n      }\n      assemblyKey {\n        id\n      }\n      assemblyCipherData\n      subAssemblies {\n        edges {\n          node {\n            id\n            singleReject\n            quorum\n            subjectCipherData\n            approvers {\n              edges {\n                node {\n                  id\n                  tp {\n                    id\n                  }\n                  sharedKey {\n                    id\n                  }\n                  sharedCipherData\n                }\n              }\n            }\n          }\n        }\n      }\n    }\n  }\n}`;\n\nexport interface CreateTpPasswordResetMutationResult {\n  createTpPasswordReset: {\n    tpPasswordReset: {\n      id: ID;\n    };\n  };\n}\nexport const CreateTpPasswordResetMutation = gqlTyped<CreateTpPasswordResetMutationResult>`\nmutation CreateTpPasswordResetMutation($input: CreateTpPasswordResetInput!) {\n  createTpPasswordReset(input: $input) {\n    tpPasswordReset {\n      id\n    }\n  }\n}`;\n\nexport interface DeleteTpPasswordResetMutationResult {\n  deleteTpPasswordReset: {\n    id: ID;\n  };\n}\nexport const DeleteTpPasswordResetMutation = gqlTyped<DeleteTpPasswordResetMutationResult>`\nmutation DeleteTpPasswordResetMutation {\n  deleteTpPasswordReset(input: {}) {\n    id\n  }\n}`;\n\nexport interface UpdateTpPasswordResetMutationResult {\n  updateTpPasswordReset: {\n    tpPasswordReset: {\n      id: ID;\n    };\n  };\n}\nexport const UpdateTpPasswordResetMutation = gqlTyped<UpdateTpPasswordResetMutationResult>`\nmutation UpdateTpPasswordResetMutation($input: UpdateTpPasswordResetInput!) {\n  updateTpPasswordReset(input: $input) {\n    tpPasswordReset {\n      id\n    }\n  }\n}`;\n"]}
|
|
236
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tp-password-reset.gql.js","sourceRoot":"/opt/atlassian/pipelines/agent/build/projects/core/src/","sources":["lib/trusted-parties/tp-password-reset.gql.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AA+D1C,MAAM,6BAA6B,GAAG,QAAQ,CAAqC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAqDjF,CAAC;AASH,MAAM,CAAC,MAAM,2BAA2B,GAAG,QAAQ,CAAmC;;;;;;;;;;EAUpF,6BAA6B;CAC9B,CAAC;AAKF,MAAM,CAAC,MAAM,0BAA0B,GAAG,QAAQ,CAAkC;;;;;;EAMlF,6BAA6B;CAC9B,CAAC;AAOF,MAAM,CAAC,MAAM,oCAAoC,GAAG,QAAQ,CAA4C;;;;;EAKtG,CAAC;AAOH,MAAM,CAAC,MAAM,oCAAoC,GAAG,QAAQ,CAA4C;;;;;;;EAOtG,CAAC;AAOH,MAAM,CAAC,MAAM,yCAAyC,GAAG,QAAQ,CAAiD;;;;;;;EAOhH,CAAC;AAOH,MAAM,CAAC,MAAM,sCAAsC,GAAG,QAAQ,CAA8C;;;;;;;EAO1G,CAAC;AASH,MAAM,CAAC,MAAM,qCAAqC,GAAG,QAAQ,CAA6C;;;;;;;;;EASxG,CAAC;AASH,MAAM,CAAC,MAAM,oCAAoC,GAAG,QAAQ,CAA4C;;;;;;;;;EAStG,CAAC;AA2CH,MAAM,CAAC,MAAM,wBAAwB,GAAG,QAAQ,CAAgC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAyC9E,CAAC;AAiDH,MAAM,CAAC,MAAM,oBAAoB,GAAG,QAAQ,CAA4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA6CtE,CAAC;AASH,MAAM,CAAC,MAAM,6BAA6B,GAAG,QAAQ,CAAqC;;;;;;;EAOxF,CAAC;AAOH,MAAM,CAAC,MAAM,6BAA6B,GAAG,QAAQ,CAAqC;;;;;EAKxF,CAAC;AASH,MAAM,CAAC,MAAM,6BAA6B,GAAG,QAAQ,CAAqC;;;;;;;EAOxF,CAAC","sourcesContent":["import { GenericScalar, ID } from '../api/types';\nimport { gqlTyped } from '../_common/ast';\nimport {\n  TpClaimState,\n  TpClaimApproverState,\n} from '../api/types/lr-graphql.types';\nimport { DateTime } from '../api/types/graphql.types';\n\nexport interface SharedTpPasswordResetFragmentResult {\n  id: ID;\n  tp: {\n    id: ID;\n    other: {\n      username: string;\n    };\n  };\n  assembly: {\n    asApprovers: {\n      edges: {\n        node: {\n          id: ID;\n          sharedKey: {\n            id: ID;\n          };\n          sharedCipherData: string;\n          sharedCipherDataClearJson: any;\n        };\n      }[];\n    };\n  };\n  sharedRequest: {\n    id: ID;\n    pxk: {\n      id: ID;\n      pbk: string;\n    };\n    claim: {\n      id: ID;\n      state: TpClaimState;\n      asClaimApprovers: {\n        edges: {\n          node: {\n            id: ID;\n            state: TpClaimApproverState;\n            sharedKey: {\n              id: ID;\n            };\n            sharedCipherApprovalData: string;\n            sharedCipherApprovalDataClearJson: any;\n            sharedCipherPartialAssemblyKey: string;\n            sharedCipherPartialAssemblyKeyClearJson: any;\n            receiverApprovals: {\n              edges: {\n                node: {\n                  id: ID;\n                };\n              }[];\n            };\n          };\n        }[];\n      };\n    };\n  };\n}\nconst SharedTpPasswordResetFragment = gqlTyped<SharedTpPasswordResetFragmentResult>`\nfragment SharedTpPasswordResetFragment on SharedTpPasswordResetNode {\n  id\n  tp {\n    id\n    other {\n      username\n    }\n  }\n  assembly {\n    asApprovers {\n      edges {\n        node {\n          id\n          sharedKey {\n            id\n          }\n          sharedCipherData\n        }\n      }\n    }\n  }\n  sharedRequest {\n    id\n    pxk {\n      id\n      pbk\n    }\n    claim {\n      id\n      state\n      asClaimApprovers {\n        edges {\n          node {\n            id\n            state\n            sharedKey {\n              id\n            }\n            sharedCipherApprovalData\n            sharedCipherPartialAssemblyKey\n            receiverApprovals {\n              edges {\n                node {\n                  id\n                }\n              }\n            }\n          }\n        }\n      }\n    }\n  }\n}`;\n\nexport interface SharedTpPasswordResetsQueryResult {\n  sharedTpPasswordResets: {\n    edges: {\n      node: SharedTpPasswordResetFragmentResult;\n    }[];\n  };\n}\nexport const SharedTpPasswordResetsQuery = gqlTyped<SharedTpPasswordResetsQueryResult>`\nquery SharedTpPasswordResetsQuery {\n  sharedTpPasswordResets {\n    edges {\n      node {\n        ...SharedTpPasswordResetFragment\n      }\n    }\n  }\n}\n${SharedTpPasswordResetFragment}\n`;\n\nexport interface SharedTpPasswordResetQueryResult {\n  sharedTpPasswordReset: SharedTpPasswordResetFragmentResult;\n}\nexport const SharedTpPasswordResetQuery = gqlTyped<SharedTpPasswordResetQueryResult>`\nquery SharedTpPasswordResetQuery($id: LrRelayIdInput!) {\n  sharedTpPasswordReset(id: $id) {\n    ...SharedTpPasswordResetFragment\n  }\n}\n${SharedTpPasswordResetFragment}\n`;\n\nexport interface CancelTpPasswordResetRequestMutationResult {\n  cancelTpPasswordResetRequest: {\n    id: ID;\n  };\n}\nexport const CancelTpPasswordResetRequestMutation = gqlTyped<CancelTpPasswordResetRequestMutationResult>`\nmutation CancelTpPasswordResetRequestMutation {\n  cancelTpPasswordResetRequest(input: {}) {\n    id\n  }\n}`;\n\nexport interface CreateTpAssemblyKeyChallengeMutationResult {\n  createTpAssemblyKeyChallenge: {\n    challenge: any;\n  };\n}\nexport const CreateTpAssemblyKeyChallengeMutation = gqlTyped<CreateTpAssemblyKeyChallengeMutationResult>`\nmutation CreateTpAssemblyKeyChallengeMutation(\n  $input: CreateTpAssemblyKeyChallengeInput!\n) {\n  createTpAssemblyKeyChallenge(input: $input) {\n    challenge\n  }\n}`;\n\nexport interface PreCompleteTpPasswordResetRequestMutationResult {\n  preCompleteTpPasswordResetRequest: {\n    idpPassword: string;\n  };\n}\nexport const PreCompleteTpPasswordResetRequestMutation = gqlTyped<PreCompleteTpPasswordResetRequestMutationResult>`\nmutation PreCompleteTpPasswordResetRequestMutation(\n  $input: PreCompleteTpPasswordResetRequestInput!\n) {\n  preCompleteTpPasswordResetRequest(input: $input) {\n    idpPassword\n  }\n}`;\n\nexport interface CompleteTpPasswordResetRequestMutationResult {\n  completeTpPasswordResetRequest: {\n    id: ID;\n  };\n}\nexport const CompleteTpPasswordResetRequestMutation = gqlTyped<CompleteTpPasswordResetRequestMutationResult>`\nmutation CompleteTpPasswordResetRequestMutation(\n  $input: CompleteTpPasswordResetRequestInput!\n) {\n  completeTpPasswordResetRequest(input: $input) {\n    id\n  }\n}`;\n\nexport interface ApproveTpPasswordResetRequestMutationResult {\n  approveTpPasswordResetRequest: {\n    claimApprover: {\n      id: ID;\n    };\n  };\n}\nexport const ApproveTpPasswordResetRequestMutation = gqlTyped<ApproveTpPasswordResetRequestMutationResult>`\nmutation ApproveTpPasswordResetRequestMutation(\n  $input: ApproveTpPasswordResetRequestInput!\n) {\n  approveTpPasswordResetRequest(input: $input) {\n    claimApprover {\n      id\n    }\n  }\n}`;\n\nexport interface RejectTpPasswordResetRequestMutationResult {\n  rejectTpPasswordResetRequest: {\n    claimApprover: {\n      id: ID;\n    };\n  };\n}\nexport const RejectTpPasswordResetRequestMutation = gqlTyped<RejectTpPasswordResetRequestMutationResult>`\nmutation RejectTpPasswordResetRequestMutation(\n  $input: RejectTpPasswordResetRequestInput!\n) {\n  rejectTpPasswordResetRequest(input: $input) {\n    claimApprover {\n      id\n    }\n  }\n}`;\n\nexport interface TpPasswordResetUserQueryResult {\n  tpPasswordResetUser: {\n    username: string;\n    resetUsername: string;\n    state: TpClaimState;\n    passKey: {\n      id: ID;\n      passKeyParams: GenericScalar;\n      passIdpParams: GenericScalar;\n    };\n    masterKey: {\n      id: ID;\n    };\n    pxk: {\n      id: ID;\n    };\n    sessionEncryptionKey: string;\n    assembly: {\n      singleReject: boolean;\n      quorum: number;\n      subAssemblies: {\n        singleReject: boolean;\n        quorum: number;\n        approvers: {\n          name: string;\n          email: string;\n          state: TpClaimApproverState;\n        }[];\n      }[];\n    };\n    approvals: {\n      id: ID;\n      modified: DateTime;\n      approverEmail: string;\n      receiverCipher: string;\n      receiverCipherPartialAssemblyKey: string;\n    }[];\n    assemblyCipherData: string;\n    wrappedAssemblyKeyVerifierPrk: string;\n  };\n}\nexport const TpPasswordResetUserQuery = gqlTyped<TpPasswordResetUserQueryResult>`\nquery TpPasswordResetUserQuery {\n  tpPasswordResetUser {\n    username\n    resetUsername\n    state\n    passKey {\n      id\n      passKeyParams\n      passIdpParams\n    }\n    masterKey {\n      id\n    }\n    pxk {\n      id\n    }\n    sessionEncryptionKey\n    assembly {\n      singleReject\n      quorum\n      subAssemblies {\n        singleReject\n        quorum\n        approvers {\n          name\n          email\n          state\n        }\n      }\n    }\n    approvals {\n      id\n      modified\n      approverEmail\n      receiverCipher\n      receiverCipherPartialAssemblyKey\n    }\n    assemblyCipherData\n    wrappedAssemblyKeyVerifierPrk\n  }\n}`;\n\nexport interface TpPasswordResetQueryResult {\n  tpPasswordReset: {\n    id: ID;\n    applied: boolean;\n    assembly: {\n      singleReject: boolean;\n      quorum: number;\n      subjectCipherData: string;\n      subjectCipherDataClearJson: any;\n      subjectKey: {\n        id: ID;\n      };\n      assemblyKey: {\n        id: ID;\n      };\n      assemblyCipherData: string;\n      subAssemblies: {\n        edges: {\n          node: {\n            id: ID;\n            singleReject: boolean;\n            quorum: number;\n            subjectCipherData: string;\n            subjectCipherDataClearJson: any;\n            subjectKey: {\n              id: ID;\n            };\n            approvers: {\n              edges: {\n                node: {\n                  id: ID;\n                  tp: {\n                    id: ID;\n                  };\n                  sharedKey: {\n                    id: ID;\n                  };\n                  sharedCipherData: string;\n                };\n              }[];\n            };\n          };\n        }[];\n      };\n    };\n  };\n}\nexport const TpPasswordResetQuery = gqlTyped<TpPasswordResetQueryResult>`\nquery TpPasswordResetQuery {\n  tpPasswordReset {\n    id\n    applied\n    assembly {\n      singleReject\n      quorum\n      subjectCipherData\n      subjectKey {\n        id\n      }\n      assemblyKey {\n        id\n      }\n      assemblyCipherData\n      subAssemblies {\n        edges {\n          node {\n            id\n            singleReject\n            quorum\n            subjectCipherData\n            subjectKey {\n              id\n            }\n            approvers {\n              edges {\n                node {\n                  id\n                  tp {\n                    id\n                  }\n                  sharedKey {\n                    id\n                  }\n                  sharedCipherData\n                }\n              }\n            }\n          }\n        }\n      }\n    }\n  }\n}`;\n\nexport interface CreateTpPasswordResetMutationResult {\n  createTpPasswordReset: {\n    tpPasswordReset: {\n      id: ID;\n    };\n  };\n}\nexport const CreateTpPasswordResetMutation = gqlTyped<CreateTpPasswordResetMutationResult>`\nmutation CreateTpPasswordResetMutation($input: CreateTpPasswordResetInput!) {\n  createTpPasswordReset(input: $input) {\n    tpPasswordReset {\n      id\n    }\n  }\n}`;\n\nexport interface DeleteTpPasswordResetMutationResult {\n  deleteTpPasswordReset: {\n    id: ID;\n  };\n}\nexport const DeleteTpPasswordResetMutation = gqlTyped<DeleteTpPasswordResetMutationResult>`\nmutation DeleteTpPasswordResetMutation {\n  deleteTpPasswordReset(input: {}) {\n    id\n  }\n}`;\n\nexport interface UpdateTpPasswordResetMutationResult {\n  updateTpPasswordReset: {\n    tpPasswordReset: {\n      id: ID;\n    };\n  };\n}\nexport const UpdateTpPasswordResetMutation = gqlTyped<UpdateTpPasswordResetMutationResult>`\nmutation UpdateTpPasswordResetMutation($input: UpdateTpPasswordResetInput!) {\n  updateTpPasswordReset(input: $input) {\n    tpPasswordReset {\n      id\n    }\n  }\n}`;\n"]}
|
|
@@ -1,39 +1,19 @@
|
|
|
1
|
-
import { __awaiter, __decorate
|
|
1
|
+
import { __awaiter, __decorate } from "tslib";
|
|
2
2
|
import { Injectable, Injector, NgZone } from '@angular/core';
|
|
3
|
-
import { KeyService } from '../cryptography/key.service';
|
|
4
|
-
import { EncryptionService } from '../cryptography/encryption.service';
|
|
5
3
|
import { CreateTpPasswordResetMutation, DeleteTpPasswordResetMutation, TpPasswordResetQuery, UpdateTpPasswordResetMutation, CancelTpPasswordResetRequestMutation, } from './tp-password-reset.gql';
|
|
6
|
-
import { KeyGraphService } from '../cryptography/key-graph.service';
|
|
7
|
-
import * as slip from '../cryptography/slip39.service';
|
|
8
|
-
import { LrBadArgumentException, LrBadLogicException, } from '../_common/exceptions';
|
|
9
|
-
import { KeyFactoryService } from '../cryptography/key-factory.service';
|
|
10
|
-
import { LrMutation, LrService } from '../api/lr-graphql';
|
|
11
4
|
import { RunOutsideAngular } from '../_common/run-outside-angular';
|
|
12
5
|
import { TP_PASSWORD_RESET_SLIP39_PASSPHRASE } from './tp-password-reset.constants';
|
|
6
|
+
import { TpPasswordResetAssemblyController } from './tp-password-reset.controller';
|
|
7
|
+
import { LrMutation, LrService } from '../api/lr-graphql';
|
|
13
8
|
import * as i0 from "@angular/core";
|
|
14
|
-
import * as i1 from "
|
|
15
|
-
import * as i2 from "../cryptography/key-factory.service";
|
|
16
|
-
import * as i3 from "../cryptography/encryption.service";
|
|
17
|
-
import * as i4 from "../cryptography/key-graph.service";
|
|
18
|
-
import * as i5 from "../cryptography/slip39.service";
|
|
19
|
-
export class CreateSubAssembliesInput {
|
|
20
|
-
}
|
|
21
|
-
export class UpdateSubAssembliesInput extends CreateSubAssembliesInput {
|
|
22
|
-
}
|
|
23
|
-
export class CreateTpPasswordResetInput {
|
|
24
|
-
}
|
|
25
|
-
export class UpdateTpPasswordResetInput extends CreateTpPasswordResetInput {
|
|
26
|
-
}
|
|
9
|
+
import * as i1 from "./tp-password-reset.controller";
|
|
27
10
|
let TpPasswordResetService = class TpPasswordResetService extends LrService {
|
|
28
|
-
constructor(ngZone, injector,
|
|
11
|
+
constructor(ngZone, injector, assemblyController) {
|
|
29
12
|
super(injector);
|
|
30
13
|
this.ngZone = ngZone;
|
|
31
14
|
this.injector = injector;
|
|
32
|
-
this.
|
|
33
|
-
this.
|
|
34
|
-
this.encryptionService = encryptionService;
|
|
35
|
-
this.keyGraph = keyGraph;
|
|
36
|
-
this.slip39Service = slip39Service;
|
|
15
|
+
this.assemblyController = assemblyController;
|
|
16
|
+
this.slip39Passphrase = TP_PASSWORD_RESET_SLIP39_PASSPHRASE;
|
|
37
17
|
}
|
|
38
18
|
getReset() {
|
|
39
19
|
return __awaiter(this, void 0, void 0, function* () {
|
|
@@ -42,20 +22,12 @@ let TpPasswordResetService = class TpPasswordResetService extends LrService {
|
|
|
42
22
|
})).tpPasswordReset;
|
|
43
23
|
});
|
|
44
24
|
}
|
|
45
|
-
|
|
46
|
-
return this.mutate(this.
|
|
25
|
+
cancelResetRequest() {
|
|
26
|
+
return this.mutate(this.cancelResetRequestMutation());
|
|
47
27
|
}
|
|
48
|
-
|
|
49
|
-
return
|
|
50
|
-
|
|
51
|
-
return this.prepareSlip39(input.createSubAssemblies, input.quorum, rawAssemblyKey);
|
|
52
|
-
}));
|
|
53
|
-
return new LrMutation({
|
|
54
|
-
mutation: CreateTpPasswordResetMutation,
|
|
55
|
-
variables: {
|
|
56
|
-
input: mutationInput,
|
|
57
|
-
},
|
|
58
|
-
});
|
|
28
|
+
cancelResetRequestMutation() {
|
|
29
|
+
return new LrMutation({
|
|
30
|
+
mutation: CancelTpPasswordResetRequestMutation,
|
|
59
31
|
});
|
|
60
32
|
}
|
|
61
33
|
deleteReset() {
|
|
@@ -66,216 +38,44 @@ let TpPasswordResetService = class TpPasswordResetService extends LrService {
|
|
|
66
38
|
mutation: DeleteTpPasswordResetMutation,
|
|
67
39
|
});
|
|
68
40
|
}
|
|
69
|
-
|
|
70
|
-
return this.
|
|
41
|
+
validateApprovers(approvers) {
|
|
42
|
+
return this.assemblyController.validateApprovers(approvers);
|
|
71
43
|
}
|
|
72
|
-
|
|
44
|
+
createReset(input) {
|
|
45
|
+
return this.mutate(this.createResetMutation(input));
|
|
46
|
+
}
|
|
47
|
+
createResetMutation(input) {
|
|
73
48
|
return __awaiter(this, void 0, void 0, function* () {
|
|
74
|
-
const
|
|
75
|
-
const { mutationInput, subjectKey, slipAssembly, assemblyKeyParams, } = yield this._createReset(input, (rawAssemblyKey) => __awaiter(this, void 0, void 0, function* () {
|
|
76
|
-
return this.prepareSlip39(input.createSubAssemblies.concat(input.updateSubAssemblies), input.quorum, rawAssemblyKey);
|
|
77
|
-
}));
|
|
78
|
-
const updateSubAssemblies = yield Promise.all(input.updateSubAssemblies.map((sa, saIndex) => __awaiter(this, void 0, void 0, function* () {
|
|
79
|
-
const subjectCipherData = yield this.encryptionService.encryptToString(subjectKey, {
|
|
80
|
-
name: sa.name,
|
|
81
|
-
});
|
|
82
|
-
// Get the existing sub-assembly
|
|
83
|
-
const existingSa = passwordReset.assembly.subAssemblies.edges.find((edge) => edge.node.id === sa.id).node;
|
|
84
|
-
// Get approvers that do not exist yet
|
|
85
|
-
const createApprovers = [];
|
|
86
|
-
const updateApprovers = [];
|
|
87
|
-
sa.approverTps.forEach((tp) => {
|
|
88
|
-
var _a;
|
|
89
|
-
const approver = (_a = existingSa.approvers.edges.find((edge) => edge.node.tp.id === tp.id)) === null || _a === void 0 ? void 0 : _a.node;
|
|
90
|
-
if (approver) {
|
|
91
|
-
updateApprovers.push({
|
|
92
|
-
tp,
|
|
93
|
-
approverId: approver.id,
|
|
94
|
-
});
|
|
95
|
-
}
|
|
96
|
-
else {
|
|
97
|
-
createApprovers.push({
|
|
98
|
-
tp,
|
|
99
|
-
});
|
|
100
|
-
}
|
|
101
|
-
});
|
|
102
|
-
return {
|
|
103
|
-
subAssemblyId: sa.id,
|
|
104
|
-
singleReject: sa.singleReject,
|
|
105
|
-
quorum: sa.quorum,
|
|
106
|
-
subjectCipherData,
|
|
107
|
-
createApprovers: yield Promise.all(createApprovers.map(({ tp }, approverIndex) => __awaiter(this, void 0, void 0, function* () {
|
|
108
|
-
return this.prepareApprover({
|
|
109
|
-
tp,
|
|
110
|
-
approverIndex,
|
|
111
|
-
saIndex: saIndex + input.createSubAssemblies.length,
|
|
112
|
-
slipAssembly,
|
|
113
|
-
assemblyKeyParams,
|
|
114
|
-
subjectKey,
|
|
115
|
-
});
|
|
116
|
-
}))),
|
|
117
|
-
updateApprovers: yield Promise.all(updateApprovers.map(({ tp, approverId }, approverIndex) => __awaiter(this, void 0, void 0, function* () {
|
|
118
|
-
return this.prepareApprover({
|
|
119
|
-
approverId,
|
|
120
|
-
tp,
|
|
121
|
-
approverIndex: approverIndex + createApprovers.length,
|
|
122
|
-
saIndex: saIndex + input.createSubAssemblies.length,
|
|
123
|
-
slipAssembly,
|
|
124
|
-
assemblyKeyParams,
|
|
125
|
-
subjectKey,
|
|
126
|
-
});
|
|
127
|
-
}))),
|
|
128
|
-
};
|
|
129
|
-
})));
|
|
49
|
+
const { mutationInput } = yield this.assemblyController.prepareCreate(input);
|
|
130
50
|
return new LrMutation({
|
|
131
|
-
mutation:
|
|
51
|
+
mutation: CreateTpPasswordResetMutation,
|
|
132
52
|
variables: {
|
|
133
|
-
input:
|
|
53
|
+
input: {
|
|
54
|
+
assembly: Object.assign({}, mutationInput),
|
|
55
|
+
},
|
|
134
56
|
},
|
|
135
57
|
});
|
|
136
58
|
});
|
|
137
59
|
}
|
|
138
|
-
|
|
139
|
-
return this.mutate(this.
|
|
140
|
-
}
|
|
141
|
-
cancelResetRequestMutation() {
|
|
142
|
-
return new LrMutation({
|
|
143
|
-
mutation: CancelTpPasswordResetRequestMutation,
|
|
144
|
-
});
|
|
145
|
-
}
|
|
146
|
-
validateApprovers(approvers) {
|
|
147
|
-
// Ensure all approvers have mkSharedKey.
|
|
148
|
-
for (const tp of approvers) {
|
|
149
|
-
if (!tp.currentUserSharedKey.userSharedKey.mkSharedKey) {
|
|
150
|
-
const msg = `tp ${tp.other.username} does not have mkSharedKey`;
|
|
151
|
-
console.log(msg);
|
|
152
|
-
throw new LrBadArgumentException(msg);
|
|
153
|
-
}
|
|
154
|
-
}
|
|
60
|
+
updateReset(input) {
|
|
61
|
+
return this.mutate(this.updateResetMutation(input));
|
|
155
62
|
}
|
|
156
|
-
|
|
63
|
+
updateResetMutation(input) {
|
|
157
64
|
return __awaiter(this, void 0, void 0, function* () {
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
// For subject to access shared_key
|
|
166
|
-
const subjectKeyWrappedSharedKey = yield this.encryptionService.encryptToString(subjectKey, sharedKey.toJSON(true));
|
|
167
|
-
const saSlip = slipAssembly.subAssemblies[saIndex];
|
|
168
|
-
if (saSlip.index !== saIndex) {
|
|
169
|
-
// Paranoia
|
|
170
|
-
throw new LrBadLogicException('slip sub assembly index should match with array index');
|
|
171
|
-
}
|
|
172
|
-
// If quorum is 1, then using the same share for every member.
|
|
173
|
-
const share = saSlip.threshold === 1 ? saSlip.shares[0] : saSlip.shares[approverIndex];
|
|
174
|
-
const partialAssemblyKey = {
|
|
175
|
-
slip39: {
|
|
176
|
-
share,
|
|
177
|
-
subAssembly: {
|
|
178
|
-
quorum: saSlip.threshold,
|
|
179
|
-
size: saSlip.size,
|
|
65
|
+
const passwordReset = yield this.getReset();
|
|
66
|
+
const { mutationInput } = yield this.assemblyController.prepareUpdate(input, passwordReset.assembly);
|
|
67
|
+
return new LrMutation({
|
|
68
|
+
mutation: UpdateTpPasswordResetMutation,
|
|
69
|
+
variables: {
|
|
70
|
+
input: {
|
|
71
|
+
assembly: Object.assign({}, mutationInput),
|
|
180
72
|
},
|
|
181
73
|
},
|
|
182
|
-
assemblyKeyParams,
|
|
183
|
-
};
|
|
184
|
-
console.log('partialAssemblyKey', partialAssemblyKey);
|
|
185
|
-
return {
|
|
186
|
-
tpMkSharedKeyId: tpMkSharedKey.id,
|
|
187
|
-
tpMkSharedKeyWrappedSharedKey,
|
|
188
|
-
subjectKeyWrappedSharedKey,
|
|
189
|
-
sharedCipherData: yield this.encryptionService.encryptToString(sharedKey, { a: '123' }),
|
|
190
|
-
sharedCipherApprovalData: '',
|
|
191
|
-
sharedCipherPartialAssemblyKey: yield this.encryptionService.encryptToString(sharedKey, partialAssemblyKey),
|
|
192
|
-
approverId: approverId || void 0,
|
|
193
|
-
tpId: approverId ? void 0 : tp.id,
|
|
194
|
-
};
|
|
195
|
-
});
|
|
196
|
-
}
|
|
197
|
-
// Prepare slip39
|
|
198
|
-
prepareSlip39(subAssemblies, assemblyQuorum, rawAssemblyKey) {
|
|
199
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
200
|
-
// Is there enough sub assemblies to meet quorum
|
|
201
|
-
if (subAssemblies.length < assemblyQuorum) {
|
|
202
|
-
throw new LrBadArgumentException('Not enough sub assemblies to meet quorum');
|
|
203
|
-
}
|
|
204
|
-
const slipAssembly = new slip.Assembly(assemblyQuorum);
|
|
205
|
-
subAssemblies.forEach((sa, index) => {
|
|
206
|
-
let approverCount = sa.approverTps.length;
|
|
207
|
-
// slip39 restricts quorum == 1 to have only 1 member. So we just share the same
|
|
208
|
-
// partial key for all sub assembly members.
|
|
209
|
-
if (sa.quorum === 1) {
|
|
210
|
-
approverCount = 1;
|
|
211
|
-
}
|
|
212
|
-
slipAssembly.addSubAssembly(new slip.SubAssembly(index, sa.quorum, approverCount));
|
|
213
74
|
});
|
|
214
|
-
yield this.slip39Service.generateShares(rawAssemblyKey, TP_PASSWORD_RESET_SLIP39_PASSPHRASE, slipAssembly);
|
|
215
|
-
return slipAssembly;
|
|
216
|
-
});
|
|
217
|
-
}
|
|
218
|
-
_createReset(input, createSlipAssembly) {
|
|
219
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
220
|
-
// Create subject key
|
|
221
|
-
const masterKey = yield this.keyService.getCurrentMasterKey();
|
|
222
|
-
const subjectKey = yield this.keyFactory.createKey();
|
|
223
|
-
const assemblyKey = yield this.keyFactory.createKey();
|
|
224
|
-
const _a = assemblyKey.toJSON(true), { k: rawAssemblyKey } = _a, assemblyKeyParams = __rest(_a, ["k"]);
|
|
225
|
-
const assemblyKeyVerifierPrk = yield this.keyFactory.createPkcSignKey();
|
|
226
|
-
const wrappedAssemblyKeyVerifierPrk = yield this.encryptionService.encryptToString(assemblyKey, assemblyKeyVerifierPrk.toJSON(true));
|
|
227
|
-
const masterKeyWrappedSubjectKey = yield this.encryptionService.encryptToString(masterKey.jwk, subjectKey.toJSON(true));
|
|
228
|
-
const subjectKeyWrappedAssemblyKey = yield this.encryptionService.encryptToString(subjectKey, assemblyKey.toJSON(true));
|
|
229
|
-
// Encrypt the rootKey with the assemblyKey
|
|
230
|
-
const rootKey = yield this.keyService.getCurrentRootKey();
|
|
231
|
-
const assemblyCipherData = yield this.encryptionService.encryptToString(assemblyKey, {
|
|
232
|
-
rootKey: rootKey.jwk.toJSON(true),
|
|
233
|
-
});
|
|
234
|
-
const slipAssembly = yield createSlipAssembly(rawAssemblyKey);
|
|
235
|
-
// const slipAssembly = await this.prepareSlip39(input.createSubAssemblies, input.quorum, rawAssemblyKey);
|
|
236
|
-
const createSubAssemblies = yield Promise.all(input.createSubAssemblies.map((sa, saIndex) => __awaiter(this, void 0, void 0, function* () {
|
|
237
|
-
const subjectCipherData = yield this.encryptionService.encryptToString(subjectKey, {
|
|
238
|
-
name: sa.name,
|
|
239
|
-
});
|
|
240
|
-
return {
|
|
241
|
-
singleReject: sa.singleReject,
|
|
242
|
-
quorum: sa.quorum,
|
|
243
|
-
subjectCipherData,
|
|
244
|
-
createApprovers: yield Promise.all(sa.approverTps.map((approverTp, approverIndex) => __awaiter(this, void 0, void 0, function* () {
|
|
245
|
-
return this.prepareApprover({
|
|
246
|
-
tp: approverTp,
|
|
247
|
-
approverIndex,
|
|
248
|
-
saIndex,
|
|
249
|
-
slipAssembly,
|
|
250
|
-
assemblyKeyParams,
|
|
251
|
-
subjectKey,
|
|
252
|
-
});
|
|
253
|
-
}))),
|
|
254
|
-
};
|
|
255
|
-
})));
|
|
256
|
-
return {
|
|
257
|
-
subjectKey,
|
|
258
|
-
slipAssembly,
|
|
259
|
-
assemblyKeyParams,
|
|
260
|
-
mutationInput: {
|
|
261
|
-
assembly: {
|
|
262
|
-
singleReject: input.singleReject,
|
|
263
|
-
quorum: input.quorum,
|
|
264
|
-
masterKeyId: masterKey.id,
|
|
265
|
-
masterKeyWrappedSubjectKey,
|
|
266
|
-
subjectKeyWrappedAssemblyKey,
|
|
267
|
-
subjectCipherData: '',
|
|
268
|
-
assemblyCipherData,
|
|
269
|
-
createSubAssemblies,
|
|
270
|
-
assemblyKeyVerifierPbk: JSON.stringify(assemblyKeyVerifierPrk.toJSON()),
|
|
271
|
-
wrappedAssemblyKeyVerifierPrk,
|
|
272
|
-
},
|
|
273
|
-
},
|
|
274
|
-
};
|
|
275
75
|
});
|
|
276
76
|
}
|
|
277
77
|
};
|
|
278
|
-
TpPasswordResetService.ɵprov = i0.ɵɵdefineInjectable({ factory: function TpPasswordResetService_Factory() { return new TpPasswordResetService(i0.ɵɵinject(i0.NgZone), i0.ɵɵinject(i0.INJECTOR), i0.ɵɵinject(i1.
|
|
78
|
+
TpPasswordResetService.ɵprov = i0.ɵɵdefineInjectable({ factory: function TpPasswordResetService_Factory() { return new TpPasswordResetService(i0.ɵɵinject(i0.NgZone), i0.ɵɵinject(i0.INJECTOR), i0.ɵɵinject(i1.TpPasswordResetAssemblyController)); }, token: TpPasswordResetService, providedIn: "root" });
|
|
279
79
|
TpPasswordResetService.decorators = [
|
|
280
80
|
{ type: Injectable, args: [{
|
|
281
81
|
providedIn: 'root',
|
|
@@ -284,11 +84,7 @@ TpPasswordResetService.decorators = [
|
|
|
284
84
|
TpPasswordResetService.ctorParameters = () => [
|
|
285
85
|
{ type: NgZone },
|
|
286
86
|
{ type: Injector },
|
|
287
|
-
{ type:
|
|
288
|
-
{ type: KeyFactoryService },
|
|
289
|
-
{ type: EncryptionService },
|
|
290
|
-
{ type: KeyGraphService },
|
|
291
|
-
{ type: slip.Slip39Service }
|
|
87
|
+
{ type: TpPasswordResetAssemblyController }
|
|
292
88
|
];
|
|
293
89
|
TpPasswordResetService = __decorate([
|
|
294
90
|
RunOutsideAngular({
|
|
@@ -296,4 +92,4 @@ TpPasswordResetService = __decorate([
|
|
|
296
92
|
})
|
|
297
93
|
], TpPasswordResetService);
|
|
298
94
|
export { TpPasswordResetService };
|
|
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"]}
|
|
95
|
+
//# 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,EACL,6BAA6B,EAC7B,6BAA6B,EAC7B,oBAAoB,EACpB,6BAA6B,EAC7B,oCAAoC,GACrC,MAAM,yBAAyB,CAAC;AAEjC,OAAO,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAC;AACnE,OAAO,EAAE,mCAAmC,EAAE,MAAM,+BAA+B,CAAC;AACpF,OAAO,EAAE,iCAAiC,EAAE,MAAM,gCAAgC,CAAC;AACnF,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;;;IAwD7C,sBAAsB,SAAtB,sBAAuB,SAAQ,SAAS;IAGnD,YACU,MAAc,EACd,QAAkB,EAClB,kBAAqD;QAE7D,KAAK,CAAC,QAAQ,CAAC,CAAC;QAJR,WAAM,GAAN,MAAM,CAAQ;QACd,aAAQ,GAAR,QAAQ,CAAU;QAClB,uBAAkB,GAAlB,kBAAkB,CAAmC;QAL/D,qBAAgB,GAAG,mCAAmC,CAAC;IAQvD,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,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,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,iBAAiB,CAAC,SAAmB;QACnC,OAAO,IAAI,CAAC,kBAAkB,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC;IAC9D,CAAC;IAED,WAAW,CAAC,KAA4B;QACtC,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC,CAAC;IACtD,CAAC;IAEK,mBAAmB,CAAC,KAA4B;;YACpD,MAAM,EAAE,aAAa,EAAE,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,aAAa,CACnE,KAAK,CACN,CAAC;YAEF,OAAO,IAAI,UAAU,CAAC;gBACpB,QAAQ,EAAE,6BAA6B;gBACvC,SAAS,EAAE;oBACT,KAAK,EAAE;wBACL,QAAQ,oBACH,aAAa,CACjB;qBACF;iBACF;aACF,CAAC,CAAC;QACL,CAAC;KAAA;IAED,WAAW,CAAC,KAA4B;QACtC,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC,CAAC;IACtD,CAAC;IAEK,mBAAmB,CAAC,KAA4B;;YACpD,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,QAAQ,EAAE,CAAC;YAE5C,MAAM,EAAE,aAAa,EAAE,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,aAAa,CACnE,KAAK,EACL,aAAa,CAAC,QAAQ,CACvB,CAAC;YAEF,OAAO,IAAI,UAAU,CAAC;gBACpB,QAAQ,EAAE,6BAA6B;gBACvC,SAAS,EAAE;oBACT,KAAK,EAAE;wBACL,QAAQ,oBACH,aAAa,CACjB;qBACF;iBACF;aACF,CAAC,CAAC;QACL,CAAC;KAAA;CACF,CAAA;;;YA1FA,UAAU,SAAC;gBACV,UAAU,EAAE,MAAM;aACnB;;;YAnE8B,MAAM;YAAhB,QAAQ;YAWpB,iCAAiC;;AAyD7B,sBAAsB;IANlC,iBAAiB,CAAC;QACjB,UAAU,EAAE,QAAQ;KACrB,CAAC;GAIW,sBAAsB,CAuFlC;SAvFY,sBAAsB","sourcesContent":["import { Injectable, Injector, NgZone } from '@angular/core';\nimport {\n  CreateTpPasswordResetMutation,\n  DeleteTpPasswordResetMutation,\n  TpPasswordResetQuery,\n  UpdateTpPasswordResetMutation,\n  CancelTpPasswordResetRequestMutation,\n} from './tp-password-reset.gql';\nimport { Key } from '../cryptography/cryptography.types';\nimport { RunOutsideAngular } from '../_common/run-outside-angular';\nimport { TP_PASSWORD_RESET_SLIP39_PASSPHRASE } from './tp-password-reset.constants';\nimport { TpPasswordResetAssemblyController } from './tp-password-reset.controller';\nimport { LrMutation, LrService } from '../api/lr-graphql';\nimport { TpNode } from '../api/types';\nimport {\n  CreateTpAssemblyInput,\n  UpdateTpAssemblyInput,\n} from './tp-assembly.types';\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  slip39Passphrase = TP_PASSWORD_RESET_SLIP39_PASSPHRASE;\n\n  constructor(\n    private ngZone: NgZone,\n    private injector: Injector,\n    private assemblyController: TpPasswordResetAssemblyController\n  ) {\n    super(injector);\n  }\n\n  async getReset() {\n    return (\n      await this.query({\n        query: TpPasswordResetQuery,\n      })\n    ).tpPasswordReset;\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  deleteReset() {\n    return this.mutate(this.deleteResetMutation());\n  }\n\n  deleteResetMutation() {\n    return new LrMutation({\n      mutation: DeleteTpPasswordResetMutation,\n    });\n  }\n\n  validateApprovers(approvers: TpNode[]): void {\n    return this.assemblyController.validateApprovers(approvers);\n  }\n\n  createReset(input: CreateTpAssemblyInput) {\n    return this.mutate(this.createResetMutation(input));\n  }\n\n  async createResetMutation(input: CreateTpAssemblyInput) {\n    const { mutationInput } = await this.assemblyController.prepareCreate(\n      input\n    );\n\n    return new LrMutation({\n      mutation: CreateTpPasswordResetMutation,\n      variables: {\n        input: {\n          assembly: {\n            ...mutationInput,\n          },\n        },\n      },\n    });\n  }\n\n  updateReset(input: UpdateTpAssemblyInput) {\n    return this.mutate(this.updateResetMutation(input));\n  }\n\n  async updateResetMutation(input: UpdateTpAssemblyInput) {\n    const passwordReset = await this.getReset();\n\n    const { mutationInput } = await this.assemblyController.prepareUpdate(\n      input,\n      passwordReset.assembly\n    );\n\n    return new LrMutation({\n      mutation: UpdateTpPasswordResetMutation,\n      variables: {\n        input: {\n          assembly: {\n            ...mutationInput,\n          },\n        },\n      },\n    });\n  }\n}\n"]}
|