@lifeready/core 1.0.10 → 1.0.11

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (74) hide show
  1. package/bundles/lifeready-core.umd.js +2769 -4786
  2. package/bundles/lifeready-core.umd.js.map +1 -1
  3. package/bundles/lifeready-core.umd.min.js +2 -2
  4. package/bundles/lifeready-core.umd.min.js.map +1 -1
  5. package/esm2015/lib/_common/utils.js +9 -1
  6. package/esm2015/lib/api/lock.service.js +10 -10
  7. package/esm2015/lib/api/lr-graphql/lr-merged-mutation.js +1 -1
  8. package/esm2015/lib/api/query-processor/query-processor.service.js +71 -1
  9. package/esm2015/lib/api/types/lr-graphql.types.js +31 -1
  10. package/esm2015/lib/auth/life-ready-auth.service.js +12 -24
  11. package/esm2015/lib/cryptography/encryption.service.js +3 -3
  12. package/esm2015/lib/cryptography/key-graph.service.js +24 -5
  13. package/esm2015/lib/items2/item2.gql.js +139 -0
  14. package/esm2015/lib/items2/item2.service.js +498 -0
  15. package/esm2015/lib/items2/item2.types.js +1 -0
  16. package/esm2015/lib/trusted-parties/tp-assembly.js +278 -0
  17. package/esm2015/lib/trusted-parties/tp-password-reset-request.service.js +4 -3
  18. package/esm2015/lib/trusted-parties/tp-password-reset.controller.js +31 -0
  19. package/esm2015/lib/trusted-parties/tp-password-reset.gql.js +5 -1
  20. package/esm2015/lib/trusted-parties/tp-password-reset.service.js +36 -240
  21. package/esm2015/lib/trusted-parties/trusted-party2.service.js +3 -3
  22. package/esm2015/lifeready-core.js +5 -3
  23. package/esm2015/public-api.js +3 -15
  24. package/fesm2015/lifeready-core.js +5004 -6707
  25. package/fesm2015/lifeready-core.js.map +1 -1
  26. package/lib/_common/utils.d.ts +6 -0
  27. package/lib/api/lock.service.d.ts +12 -3
  28. package/lib/api/lr-graphql/lr-merged-mutation.d.ts +1 -0
  29. package/lib/api/query-processor/query-processor.service.d.ts +1 -1
  30. package/lib/api/types/lr-graphql.types.d.ts +105 -2
  31. package/lib/auth/life-ready-auth.service.d.ts +3 -1
  32. package/lib/cryptography/key-graph.service.d.ts +9 -1
  33. package/lib/{api → items2}/item2.gql.d.ts +28 -1
  34. package/lib/items2/item2.service.d.ts +203 -0
  35. package/lib/items2/item2.types.d.ts +70 -0
  36. package/lib/trusted-parties/tp-assembly.d.ts +206 -0
  37. package/lib/trusted-parties/tp-password-reset-request.service.d.ts +3 -3
  38. package/lib/trusted-parties/tp-password-reset.controller.d.ts +8 -0
  39. package/lib/trusted-parties/tp-password-reset.gql.d.ts +5 -0
  40. package/lib/trusted-parties/tp-password-reset.service.d.ts +99 -41
  41. package/lib/trusted-parties/trusted-party2.service.d.ts +1 -1
  42. package/lifeready-core.d.ts +4 -2
  43. package/lifeready-core.metadata.json +1 -1
  44. package/package.json +1 -1
  45. package/public-api.d.ts +2 -14
  46. package/esm2015/lib/api/item2.gql.js +0 -110
  47. package/esm2015/lib/api/item2.service.js +0 -311
  48. package/esm2015/lib/scenario/approvals/scenario-approval.gql.js +0 -105
  49. package/esm2015/lib/scenario/approvals/scenario-approval.types.js +0 -1
  50. package/esm2015/lib/scenario/approvals/scenario-approver.service.js +0 -300
  51. package/esm2015/lib/scenario/claimants/scenario-claimant.gql.js +0 -52
  52. package/esm2015/lib/scenario/claimants/scenario-claimant.service.js +0 -97
  53. package/esm2015/lib/scenario/claimants/scenario-claimant.types.js +0 -1
  54. package/esm2015/lib/scenario/receivers/scenario-receiver.gql.js +0 -150
  55. package/esm2015/lib/scenario/receivers/scenario-receiver.service.js +0 -229
  56. package/esm2015/lib/scenario/receivers/scenario-receiver.types.js +0 -1
  57. package/esm2015/lib/scenario/scenario-setup.service.js +0 -269
  58. package/esm2015/lib/scenario/scenario.gql.js +0 -368
  59. package/esm2015/lib/scenario/scenario.service.js +0 -611
  60. package/esm2015/lib/scenario/scenario.types.js +0 -64
  61. package/lib/api/item2.service.d.ts +0 -177
  62. package/lib/scenario/approvals/scenario-approval.gql.d.ts +0 -7
  63. package/lib/scenario/approvals/scenario-approval.types.d.ts +0 -63
  64. package/lib/scenario/approvals/scenario-approver.service.d.ts +0 -32
  65. package/lib/scenario/claimants/scenario-claimant.gql.d.ts +0 -5
  66. package/lib/scenario/claimants/scenario-claimant.service.d.ts +0 -17
  67. package/lib/scenario/claimants/scenario-claimant.types.d.ts +0 -18
  68. package/lib/scenario/receivers/scenario-receiver.gql.d.ts +0 -8
  69. package/lib/scenario/receivers/scenario-receiver.service.d.ts +0 -30
  70. package/lib/scenario/receivers/scenario-receiver.types.d.ts +0 -54
  71. package/lib/scenario/scenario-setup.service.d.ts +0 -22
  72. package/lib/scenario/scenario.gql.d.ts +0 -34
  73. package/lib/scenario/scenario.service.d.ts +0 -58
  74. package/lib/scenario/scenario.types.d.ts +0 -217
@@ -1,39 +1,19 @@
1
- import { __awaiter, __decorate, __rest } from "tslib";
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 "../cryptography/key.service";
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, keyService, keyFactory, encryptionService, keyGraph, slip39Service) {
11
+ constructor(ngZone, injector, assemblyController) {
29
12
  super(injector);
30
13
  this.ngZone = ngZone;
31
14
  this.injector = injector;
32
- this.keyService = keyService;
33
- this.keyFactory = keyFactory;
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
- createReset(input) {
46
- return this.mutate(this.createResetMutation(input));
25
+ cancelResetRequest() {
26
+ return this.mutate(this.cancelResetRequestMutation());
47
27
  }
48
- createResetMutation(input) {
49
- return __awaiter(this, void 0, void 0, function* () {
50
- const { mutationInput } = yield this._createReset(input, (rawAssemblyKey) => __awaiter(this, void 0, void 0, function* () {
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
- updateReset(input) {
70
- return this.mutate(this.updateResetMutation(input));
41
+ validateApprovers(approvers) {
42
+ return this.assemblyController.validateApprovers(approvers);
71
43
  }
72
- updateResetMutation(input) {
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 passwordReset = yield this.getReset();
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: UpdateTpPasswordResetMutation,
51
+ mutation: CreateTpPasswordResetMutation,
132
52
  variables: {
133
- input: Object.assign(Object.assign({}, mutationInput), { assembly: Object.assign(Object.assign({}, mutationInput.assembly), { updateSubAssemblies }) }),
53
+ input: {
54
+ assembly: Object.assign({}, mutationInput),
55
+ },
134
56
  },
135
57
  });
136
58
  });
137
59
  }
138
- cancelResetRequest() {
139
- return this.mutate(this.cancelResetRequestMutation());
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
- prepareApprover({ approverId, tp, approverIndex, saIndex, slipAssembly, assemblyKeyParams, subjectKey, }) {
63
+ updateResetMutation(input) {
157
64
  return __awaiter(this, void 0, void 0, function* () {
158
- if (!tp.currentUserSharedKey.userSharedKey.mkSharedKey) {
159
- throw new LrBadArgumentException(`Tp ${tp.other.username} does not have mkSharedKey. Need to reshared it first.`);
160
- }
161
- const sharedKey = yield this.keyFactory.createKey();
162
- const tpMkSharedKey = yield this.keyGraph.getKey(tp.currentUserSharedKey.userSharedKey.mkSharedKey.id);
163
- // For TP to access shared_key
164
- const tpMkSharedKeyWrappedSharedKey = yield this.encryptionService.encryptToString(tpMkSharedKey.jwk, sharedKey.toJSON(true));
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.KeyService), i0.ɵɵinject(i2.KeyFactoryService), i0.ɵɵinject(i3.EncryptionService), i0.ɵɵinject(i4.KeyGraphService), i0.ɵɵinject(i5.Slip39Service)); }, token: TpPasswordResetService, providedIn: "root" });
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: KeyService },
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":"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","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 { CreateTpAssemblyInput, UpdateTpAssemblyInput } from './tp-assembly';\nimport { TpPasswordResetAssemblyController } from './tp-password-reset.controller';\nimport { LrMutation, LrService } from '../api/lr-graphql';\nimport { TpNode } from '../api/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"]}
@@ -1,7 +1,7 @@
1
1
  import { __awaiter, __decorate } from "tslib";
2
2
  import { Injectable, NgZone } from '@angular/core';
3
3
  import { JWK } from 'node-jose';
4
- import { Item2Service } from '../api/item2.service';
4
+ import { Item2Service } from '../items2/item2.service';
5
5
  import { LrGraphQLService, LrMutation } from '../api/lr-graphql';
6
6
  import { EncryptionService } from '../cryptography/encryption.service';
7
7
  import { KeyFactoryService } from '../cryptography/key-factory.service';
@@ -13,7 +13,7 @@ import { CompleteTpMkReshareMutation, DeleteTpMutation, RequestTpMkReshareMutati
13
13
  import * as i0 from "@angular/core";
14
14
  import * as i1 from "../cryptography/key-graph.service";
15
15
  import * as i2 from "../api/lr-graphql/lr-graphql.service";
16
- import * as i3 from "../api/item2.service";
16
+ import * as i3 from "../items2/item2.service";
17
17
  import * as i4 from "../cryptography/key.service";
18
18
  import * as i5 from "../cryptography/key-factory.service";
19
19
  import * as i6 from "../cryptography/encryption.service";
@@ -212,4 +212,4 @@ TrustedParty2Service = __decorate([
212
212
  })
213
213
  ], TrustedParty2Service);
214
214
  export { TrustedParty2Service };
215
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"trusted-party2.service.js","sourceRoot":"/opt/atlassian/pipelines/agent/build/projects/core/src/","sources":["lib/trusted-parties/trusted-party2.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, NgZone } from '@angular/core';\nimport { min } from 'moment';\nimport { JWK } from 'node-jose';\nimport { Item2Service } from '../api/item2.service';\nimport { LrGraphQLService, LrMutation } from '../api/lr-graphql';\nimport { AccessRoleChoice, LrRelayIdInput } from '../api/types';\nimport { Key } from '../cryptography/cryptography.types';\nimport { EncryptionService } from '../cryptography/encryption.service';\nimport { KeyFactoryService } from '../cryptography/key-factory.service';\nimport { KeyGraphService } from '../cryptography/key-graph.service';\nimport { KeyService } from '../cryptography/key.service';\nimport { LrBadStateException } from '../_common/exceptions';\nimport { RunOutsideAngular } from '../_common/run-outside-angular';\nimport {\n  CompleteTpMkReshareMutation,\n  DeleteTpMutation,\n  RequestTpMkReshareMutation,\n  RespondTpMkReshareMutation,\n  ShareDirectoryMutation,\n  ShareFileMutation,\n  TpCurrentUserSharedKeyQuery,\n  UnshareDirectoryMutation,\n  UnshareFileMutation,\n} from './trusted-party2.gql';\n\n// If xxxKeyId not given, then fetch them with API calls\nexport interface ShareItemOptions {\n  itemId: LrRelayIdInput;\n  itemKeyId?: LrRelayIdInput;\n  tpId: LrRelayIdInput;\n  tpSharedKeyId?: LrRelayIdInput;\n  accessRole: AccessRoleChoice;\n}\n\nexport interface UnshareItemOptions {\n  itemId: string;\n  tpId: string;\n}\n\n@RunOutsideAngular({\n  ngZoneName: 'ngZone',\n})\n@Injectable({\n  providedIn: 'root',\n})\nexport class TrustedParty2Service {\n  constructor(\n    private ngZone: NgZone,\n    private keyGraph: KeyGraphService,\n    private lrGraphQL: LrGraphQLService,\n    private item2Service: Item2Service,\n    private keyService: KeyService,\n    private keyFactory: KeyFactoryService,\n    private encryptionService: EncryptionService\n  ) {}\n\n  // TODO: deprecate this\n  public deleteTp(tpId: LrRelayIdInput) {\n    return this.deleteTpMutation(tpId);\n  }\n\n  public deleteTpMutation(tpId: LrRelayIdInput) {\n    return new LrMutation({\n      mutation: DeleteTpMutation,\n      variables: {\n        input: {\n          id: tpId,\n        },\n      },\n    });\n  }\n\n  async getTpCurrentUserSharedKey(tpId: LrRelayIdInput) {\n    return (\n      await this.lrGraphQL.query({\n        query: TpCurrentUserSharedKeyQuery,\n        variables: {\n          id: tpId,\n        },\n      })\n    ).tp.currentUserSharedKey.userSharedKey;\n  }\n\n  async shareDirectory(options: ShareItemOptions) {\n    return this.shareItem({ ...options, isDirectory: true });\n  }\n\n  async shareFile(options: ShareItemOptions) {\n    return this.shareItem({ ...options, isDirectory: false });\n  }\n\n  private async shareItem({\n    itemId,\n    itemKeyId,\n    tpId,\n    tpSharedKeyId,\n    accessRole,\n    isDirectory,\n  }: ShareItemOptions & {\n    isDirectory: boolean;\n  }) {\n    const itemKey = await this.keyGraph.getKey(itemKeyId, () =>\n      isDirectory\n        ? this.item2Service.getDirectoryKeyId(itemId)\n        : this.item2Service.getFileKeyId(itemId)\n    );\n    const wrappingKey = await this.keyGraph.getKey(tpSharedKeyId, () =>\n      this.getTpCurrentUserSharedKey(tpId).then((res) => res.sharedKey.id)\n    );\n    const wrappedKey = await this.keyGraph.wrapKey(wrappingKey, itemKey.jwk);\n\n    return new LrMutation({\n      mutation: isDirectory ? ShareDirectoryMutation : ShareFileMutation,\n      variables: {\n        input: {\n          id: itemId,\n          tpId,\n          accessRole,\n          keyId: itemKey.id,\n          wrappingKeyId: wrappingKey.id,\n          wrappedKey,\n        },\n      },\n    });\n  }\n\n  async unshareDirectory(options: UnshareItemOptions) {\n    return this.unshareItem({ ...options, isDirectory: true });\n  }\n\n  async unshareFile(options: UnshareItemOptions) {\n    return this.unshareItem({ ...options, isDirectory: false });\n  }\n\n  private async unshareItem({\n    itemId,\n    tpId,\n    isDirectory,\n  }: UnshareItemOptions & { isDirectory: boolean }) {\n    return new LrMutation({\n      mutation: isDirectory ? UnshareDirectoryMutation : UnshareFileMutation,\n      variables: {\n        input: {\n          id: itemId,\n          tpId,\n        },\n      },\n    });\n  }\n\n  public async requestMkReshare(tpId: LrRelayIdInput) {\n    const userSharedKey = await this.getTpCurrentUserSharedKey(tpId);\n\n    if (userSharedKey.mkSharedKey) {\n      throw new LrBadStateException('TP already has mkSharedKey');\n    }\n\n    const masterKey = await this.keyService.getCurrentMasterKey();\n    const prk = await this.keyFactory.createPkcKey();\n    const mkWrappedMkPrk = await this.encryptionService.encryptToString(\n      masterKey.jwk,\n      prk.toJSON(true)\n    );\n\n    const sharedKey = await this.keyGraph.getKey(userSharedKey.sharedKey.id);\n    const mkReshareRequestCipher = await this.encryptionService.encryptToString(\n      sharedKey.jwk,\n      {\n        pbk: prk.toJSON(),\n      }\n    );\n\n    return await new LrMutation({\n      mutation: RequestTpMkReshareMutation,\n      variables: {\n        input: {\n          tpId,\n          masterKeyId: masterKey.id,\n          mkPbk: JSON.stringify(prk.toJSON()),\n          mkWrappedMkPrk,\n          sharedKeyId: sharedKey.id,\n          mkReshareRequestCipher,\n        },\n      },\n    });\n  }\n\n  public async respondMkReshare(tpId: LrRelayIdInput) {\n    const userSharedKey = await this.getTpCurrentUserSharedKey(tpId);\n\n    if (!userSharedKey.mkSharedKey) {\n      throw new LrBadStateException(\n        'No access to the mkSharedKey so cannot reshare it with TP'\n      );\n    }\n\n    const sharedKey = await this.keyGraph.getKey(userSharedKey.sharedKey.id);\n    const plainMkReshareRequestCipher = await this.encryptionService.decrypt(\n      sharedKey,\n      userSharedKey.mkReshareRequestCipher\n    );\n    const pbk = await JWK.asKey(plainMkReshareRequestCipher.pbk);\n    const mkSharedKey = await this.keyGraph.getKey(\n      userSharedKey.mkSharedKey.id\n    );\n\n    const plainMkReshareResponseCipher = {\n      mkSharedKey: {\n        id: mkSharedKey.id,\n        jwk: mkSharedKey.jwk.toJSON(true),\n      },\n    };\n\n    // Wrap with sharedKey then again with Pbk\n    const mkReshareResponseCipher = await this.encryptionService.encryptToString(\n      pbk,\n      await this.encryptionService.encryptToString(\n        sharedKey.jwk,\n        plainMkReshareResponseCipher\n      )\n    );\n\n    return new LrMutation({\n      mutation: RespondTpMkReshareMutation,\n      variables: {\n        input: {\n          tpId,\n          mkSharedKeyId: mkSharedKey.id,\n          mkReshareResponseCipher,\n        },\n      },\n    });\n  }\n\n  public async completeMkReshare(tpId: LrRelayIdInput) {\n    const userSharedKey = await this.getTpCurrentUserSharedKey(tpId);\n\n    const sharedKey = await this.keyGraph.getKey(userSharedKey.sharedKey.id);\n    const prk = await this.keyGraph.getKey(userSharedKey.mkPxk.id);\n    const plainMkReshareResponseCipher = await this.encryptionService.decrypt(\n      sharedKey,\n      await this.encryptionService.decrypt(\n        prk,\n        userSharedKey.mkReshareResponseCipher\n      )\n    );\n\n    // Double check it's a valid key.\n    const mkSharedKey: Key = {\n      id: plainMkReshareResponseCipher.mkSharedKey.id,\n      jwk: await JWK.asKey(plainMkReshareResponseCipher.mkSharedKey.jwk),\n    };\n\n    const masterKey = await this.keyService.getCurrentMasterKey();\n    const mkWrappedMkSharedKey = await this.encryptionService.encryptToString(\n      masterKey.jwk,\n      mkSharedKey.jwk.toJSON(true)\n    );\n\n    return new LrMutation({\n      mutation: CompleteTpMkReshareMutation,\n      variables: {\n        input: {\n          tpId,\n          masterKeyId: masterKey.id,\n          mkSharedKeyId: mkSharedKey.id,\n          mkWrappedMkSharedKey,\n        },\n      },\n    });\n  }\n}\n"]}
215
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"trusted-party2.service.js","sourceRoot":"/opt/atlassian/pipelines/agent/build/projects/core/src/","sources":["lib/trusted-parties/trusted-party2.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, NgZone } from '@angular/core';\nimport { min } from 'moment';\nimport { JWK } from 'node-jose';\nimport { Item2Service } from '../items2/item2.service';\nimport { LrGraphQLService, LrMutation } from '../api/lr-graphql';\nimport { AccessRoleChoice, LrRelayIdInput } from '../api/types';\nimport { Key } from '../cryptography/cryptography.types';\nimport { EncryptionService } from '../cryptography/encryption.service';\nimport { KeyFactoryService } from '../cryptography/key-factory.service';\nimport { KeyGraphService } from '../cryptography/key-graph.service';\nimport { KeyService } from '../cryptography/key.service';\nimport { LrBadStateException } from '../_common/exceptions';\nimport { RunOutsideAngular } from '../_common/run-outside-angular';\nimport {\n  CompleteTpMkReshareMutation,\n  DeleteTpMutation,\n  RequestTpMkReshareMutation,\n  RespondTpMkReshareMutation,\n  ShareDirectoryMutation,\n  ShareFileMutation,\n  TpCurrentUserSharedKeyQuery,\n  UnshareDirectoryMutation,\n  UnshareFileMutation,\n} from './trusted-party2.gql';\n\n// If xxxKeyId not given, then fetch them with API calls\nexport interface ShareItemOptions {\n  itemId: LrRelayIdInput;\n  itemKeyId?: LrRelayIdInput;\n  tpId: LrRelayIdInput;\n  tpSharedKeyId?: LrRelayIdInput;\n  accessRole: AccessRoleChoice;\n}\n\nexport interface UnshareItemOptions {\n  itemId: string;\n  tpId: string;\n}\n\n@RunOutsideAngular({\n  ngZoneName: 'ngZone',\n})\n@Injectable({\n  providedIn: 'root',\n})\nexport class TrustedParty2Service {\n  constructor(\n    private ngZone: NgZone,\n    private keyGraph: KeyGraphService,\n    private lrGraphQL: LrGraphQLService,\n    private item2Service: Item2Service,\n    private keyService: KeyService,\n    private keyFactory: KeyFactoryService,\n    private encryptionService: EncryptionService\n  ) {}\n\n  // TODO: deprecate this\n  public deleteTp(tpId: LrRelayIdInput) {\n    return this.deleteTpMutation(tpId);\n  }\n\n  public deleteTpMutation(tpId: LrRelayIdInput) {\n    return new LrMutation({\n      mutation: DeleteTpMutation,\n      variables: {\n        input: {\n          id: tpId,\n        },\n      },\n    });\n  }\n\n  async getTpCurrentUserSharedKey(tpId: LrRelayIdInput) {\n    return (\n      await this.lrGraphQL.query({\n        query: TpCurrentUserSharedKeyQuery,\n        variables: {\n          id: tpId,\n        },\n      })\n    ).tp.currentUserSharedKey.userSharedKey;\n  }\n\n  async shareDirectory(options: ShareItemOptions) {\n    return this.shareItem({ ...options, isDirectory: true });\n  }\n\n  async shareFile(options: ShareItemOptions) {\n    return this.shareItem({ ...options, isDirectory: false });\n  }\n\n  private async shareItem({\n    itemId,\n    itemKeyId,\n    tpId,\n    tpSharedKeyId,\n    accessRole,\n    isDirectory,\n  }: ShareItemOptions & {\n    isDirectory: boolean;\n  }) {\n    const itemKey = await this.keyGraph.getKey(itemKeyId, () =>\n      isDirectory\n        ? this.item2Service.getDirectoryKeyId(itemId)\n        : this.item2Service.getFileKeyId(itemId)\n    );\n    const wrappingKey = await this.keyGraph.getKey(tpSharedKeyId, () =>\n      this.getTpCurrentUserSharedKey(tpId).then((res) => res.sharedKey.id)\n    );\n    const wrappedKey = await this.keyGraph.wrapKey(wrappingKey, itemKey.jwk);\n\n    return new LrMutation({\n      mutation: isDirectory ? ShareDirectoryMutation : ShareFileMutation,\n      variables: {\n        input: {\n          id: itemId,\n          tpId,\n          accessRole,\n          keyId: itemKey.id,\n          wrappingKeyId: wrappingKey.id,\n          wrappedKey,\n        },\n      },\n    });\n  }\n\n  async unshareDirectory(options: UnshareItemOptions) {\n    return this.unshareItem({ ...options, isDirectory: true });\n  }\n\n  async unshareFile(options: UnshareItemOptions) {\n    return this.unshareItem({ ...options, isDirectory: false });\n  }\n\n  private async unshareItem({\n    itemId,\n    tpId,\n    isDirectory,\n  }: UnshareItemOptions & { isDirectory: boolean }) {\n    return new LrMutation({\n      mutation: isDirectory ? UnshareDirectoryMutation : UnshareFileMutation,\n      variables: {\n        input: {\n          id: itemId,\n          tpId,\n        },\n      },\n    });\n  }\n\n  public async requestMkReshare(tpId: LrRelayIdInput) {\n    const userSharedKey = await this.getTpCurrentUserSharedKey(tpId);\n\n    if (userSharedKey.mkSharedKey) {\n      throw new LrBadStateException('TP already has mkSharedKey');\n    }\n\n    const masterKey = await this.keyService.getCurrentMasterKey();\n    const prk = await this.keyFactory.createPkcKey();\n    const mkWrappedMkPrk = await this.encryptionService.encryptToString(\n      masterKey.jwk,\n      prk.toJSON(true)\n    );\n\n    const sharedKey = await this.keyGraph.getKey(userSharedKey.sharedKey.id);\n    const mkReshareRequestCipher = await this.encryptionService.encryptToString(\n      sharedKey.jwk,\n      {\n        pbk: prk.toJSON(),\n      }\n    );\n\n    return await new LrMutation({\n      mutation: RequestTpMkReshareMutation,\n      variables: {\n        input: {\n          tpId,\n          masterKeyId: masterKey.id,\n          mkPbk: JSON.stringify(prk.toJSON()),\n          mkWrappedMkPrk,\n          sharedKeyId: sharedKey.id,\n          mkReshareRequestCipher,\n        },\n      },\n    });\n  }\n\n  public async respondMkReshare(tpId: LrRelayIdInput) {\n    const userSharedKey = await this.getTpCurrentUserSharedKey(tpId);\n\n    if (!userSharedKey.mkSharedKey) {\n      throw new LrBadStateException(\n        'No access to the mkSharedKey so cannot reshare it with TP'\n      );\n    }\n\n    const sharedKey = await this.keyGraph.getKey(userSharedKey.sharedKey.id);\n    const plainMkReshareRequestCipher = await this.encryptionService.decrypt(\n      sharedKey,\n      userSharedKey.mkReshareRequestCipher\n    );\n    const pbk = await JWK.asKey(plainMkReshareRequestCipher.pbk);\n    const mkSharedKey = await this.keyGraph.getKey(\n      userSharedKey.mkSharedKey.id\n    );\n\n    const plainMkReshareResponseCipher = {\n      mkSharedKey: {\n        id: mkSharedKey.id,\n        jwk: mkSharedKey.jwk.toJSON(true),\n      },\n    };\n\n    // Wrap with sharedKey then again with Pbk\n    const mkReshareResponseCipher = await this.encryptionService.encryptToString(\n      pbk,\n      await this.encryptionService.encryptToString(\n        sharedKey.jwk,\n        plainMkReshareResponseCipher\n      )\n    );\n\n    return new LrMutation({\n      mutation: RespondTpMkReshareMutation,\n      variables: {\n        input: {\n          tpId,\n          mkSharedKeyId: mkSharedKey.id,\n          mkReshareResponseCipher,\n        },\n      },\n    });\n  }\n\n  public async completeMkReshare(tpId: LrRelayIdInput) {\n    const userSharedKey = await this.getTpCurrentUserSharedKey(tpId);\n\n    const sharedKey = await this.keyGraph.getKey(userSharedKey.sharedKey.id);\n    const prk = await this.keyGraph.getKey(userSharedKey.mkPxk.id);\n    const plainMkReshareResponseCipher = await this.encryptionService.decrypt(\n      sharedKey,\n      await this.encryptionService.decrypt(\n        prk,\n        userSharedKey.mkReshareResponseCipher\n      )\n    );\n\n    // Double check it's a valid key.\n    const mkSharedKey: Key = {\n      id: plainMkReshareResponseCipher.mkSharedKey.id,\n      jwk: await JWK.asKey(plainMkReshareResponseCipher.mkSharedKey.jwk),\n    };\n\n    const masterKey = await this.keyService.getCurrentMasterKey();\n    const mkWrappedMkSharedKey = await this.encryptionService.encryptToString(\n      masterKey.jwk,\n      mkSharedKey.jwk.toJSON(true)\n    );\n\n    return new LrMutation({\n      mutation: CompleteTpMkReshareMutation,\n      variables: {\n        input: {\n          tpId,\n          masterKeyId: masterKey.id,\n          mkSharedKeyId: mkSharedKey.id,\n          mkWrappedMkSharedKey,\n        },\n      },\n    });\n  }\n}\n"]}
@@ -3,8 +3,10 @@
3
3
  */
4
4
  export * from './public-api';
5
5
  export { RunOutsideAngular as ɵd } from './lib/_common/run-outside-angular';
6
- export { LrGraphQLService as ɵb, LrService as ɵg } from './lib/api/lr-graphql';
6
+ export { LrGraphQLService as ɵb, LrService as ɵi } from './lib/api/lr-graphql';
7
7
  export { TpPasswordResetProcessorService as ɵc } from './lib/api/query-processor/tp-password-reset-processor.service';
8
- export { SharedContactCardFields as ɵe, SharedContactCardService as ɵf } from './lib/api/shared-contact-card.service';
8
+ export { SharedContactCardFields as ɵg, SharedContactCardService as ɵh } from './lib/api/shared-contact-card.service';
9
9
  export { TimeService as ɵa } from './lib/api/time.service';
10
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlmZXJlYWR5LWNvcmUuanMiLCJzb3VyY2VSb290IjoiL29wdC9hdGxhc3NpYW4vcGlwZWxpbmVzL2FnZW50L2J1aWxkL3Byb2plY3RzL2NvcmUvc3JjLyIsInNvdXJjZXMiOlsibGlmZXJlYWR5LWNvcmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQztBQUU3QixPQUFPLEVBQUMsaUJBQWlCLElBQUksRUFBRSxFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFDMUUsT0FBTyxFQUFDLGdCQUFnQixJQUFJLEVBQUUsRUFBQyxTQUFTLElBQUksRUFBRSxFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFDNUUsT0FBTyxFQUFDLCtCQUErQixJQUFJLEVBQUUsRUFBQyxNQUFNLCtEQUErRCxDQUFDO0FBQ3BILE9BQU8sRUFBQyx1QkFBdUIsSUFBSSxFQUFFLEVBQUMsd0JBQXdCLElBQUksRUFBRSxFQUFDLE1BQU0sdUNBQXVDLENBQUM7QUFDbkgsT0FBTyxFQUFDLFdBQVcsSUFBSSxFQUFFLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcblxuZXhwb3J0IHtSdW5PdXRzaWRlQW5ndWxhciBhcyDJtWR9IGZyb20gJy4vbGliL19jb21tb24vcnVuLW91dHNpZGUtYW5ndWxhcic7XG5leHBvcnQge0xyR3JhcGhRTFNlcnZpY2UgYXMgybViLExyU2VydmljZSBhcyDJtWd9IGZyb20gJy4vbGliL2FwaS9sci1ncmFwaHFsJztcbmV4cG9ydCB7VHBQYXNzd29yZFJlc2V0UHJvY2Vzc29yU2VydmljZSBhcyDJtWN9IGZyb20gJy4vbGliL2FwaS9xdWVyeS1wcm9jZXNzb3IvdHAtcGFzc3dvcmQtcmVzZXQtcHJvY2Vzc29yLnNlcnZpY2UnO1xuZXhwb3J0IHtTaGFyZWRDb250YWN0Q2FyZEZpZWxkcyBhcyDJtWUsU2hhcmVkQ29udGFjdENhcmRTZXJ2aWNlIGFzIMm1Zn0gZnJvbSAnLi9saWIvYXBpL3NoYXJlZC1jb250YWN0LWNhcmQuc2VydmljZSc7XG5leHBvcnQge1RpbWVTZXJ2aWNlIGFzIMm1YX0gZnJvbSAnLi9saWIvYXBpL3RpbWUuc2VydmljZSc7Il19
10
+ export { TpAssemblyController as ɵf } from './lib/trusted-parties/tp-assembly';
11
+ export { TpPasswordResetAssemblyController as ɵe } from './lib/trusted-parties/tp-password-reset.controller';
12
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlmZXJlYWR5LWNvcmUuanMiLCJzb3VyY2VSb290IjoiL29wdC9hdGxhc3NpYW4vcGlwZWxpbmVzL2FnZW50L2J1aWxkL3Byb2plY3RzL2NvcmUvc3JjLyIsInNvdXJjZXMiOlsibGlmZXJlYWR5LWNvcmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQztBQUU3QixPQUFPLEVBQUMsaUJBQWlCLElBQUksRUFBRSxFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFDMUUsT0FBTyxFQUFDLGdCQUFnQixJQUFJLEVBQUUsRUFBQyxTQUFTLElBQUksRUFBRSxFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFDNUUsT0FBTyxFQUFDLCtCQUErQixJQUFJLEVBQUUsRUFBQyxNQUFNLCtEQUErRCxDQUFDO0FBQ3BILE9BQU8sRUFBQyx1QkFBdUIsSUFBSSxFQUFFLEVBQUMsd0JBQXdCLElBQUksRUFBRSxFQUFDLE1BQU0sdUNBQXVDLENBQUM7QUFDbkgsT0FBTyxFQUFDLFdBQVcsSUFBSSxFQUFFLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQztBQUN6RCxPQUFPLEVBQUMsb0JBQW9CLElBQUksRUFBRSxFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFDN0UsT0FBTyxFQUFDLGlDQUFpQyxJQUFJLEVBQUUsRUFBQyxNQUFNLG9EQUFvRCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpYy1hcGknO1xuXG5leHBvcnQge1J1bk91dHNpZGVBbmd1bGFyIGFzIMm1ZH0gZnJvbSAnLi9saWIvX2NvbW1vbi9ydW4tb3V0c2lkZS1hbmd1bGFyJztcbmV4cG9ydCB7THJHcmFwaFFMU2VydmljZSBhcyDJtWIsTHJTZXJ2aWNlIGFzIMm1aX0gZnJvbSAnLi9saWIvYXBpL2xyLWdyYXBocWwnO1xuZXhwb3J0IHtUcFBhc3N3b3JkUmVzZXRQcm9jZXNzb3JTZXJ2aWNlIGFzIMm1Y30gZnJvbSAnLi9saWIvYXBpL3F1ZXJ5LXByb2Nlc3Nvci90cC1wYXNzd29yZC1yZXNldC1wcm9jZXNzb3Iuc2VydmljZSc7XG5leHBvcnQge1NoYXJlZENvbnRhY3RDYXJkRmllbGRzIGFzIMm1ZyxTaGFyZWRDb250YWN0Q2FyZFNlcnZpY2UgYXMgybVofSBmcm9tICcuL2xpYi9hcGkvc2hhcmVkLWNvbnRhY3QtY2FyZC5zZXJ2aWNlJztcbmV4cG9ydCB7VGltZVNlcnZpY2UgYXMgybVhfSBmcm9tICcuL2xpYi9hcGkvdGltZS5zZXJ2aWNlJztcbmV4cG9ydCB7VHBBc3NlbWJseUNvbnRyb2xsZXIgYXMgybVmfSBmcm9tICcuL2xpYi90cnVzdGVkLXBhcnRpZXMvdHAtYXNzZW1ibHknO1xuZXhwb3J0IHtUcFBhc3N3b3JkUmVzZXRBc3NlbWJseUNvbnRyb2xsZXIgYXMgybVlfSBmcm9tICcuL2xpYi90cnVzdGVkLXBhcnRpZXMvdHAtcGFzc3dvcmQtcmVzZXQuY29udHJvbGxlcic7Il19
@@ -40,19 +40,6 @@ export * from './lib/record-type/record-type.service';
40
40
  export * from './lib/trusted-parties/trusted-party.types';
41
41
  export * from './lib/trusted-parties/trusted-party.gql';
42
42
  export * from './lib/trusted-parties/trusted-party.service';
43
- export * from './lib/scenario/scenario.types';
44
- export * from './lib/scenario/scenario.gql';
45
- export * from './lib/scenario/scenario.service';
46
- export * from './lib/scenario/scenario-setup.service';
47
- export * from './lib/scenario/approvals/scenario-approval.types';
48
- export * from './lib/scenario/approvals/scenario-approval.gql';
49
- export * from './lib/scenario/approvals/scenario-approver.service';
50
- export * from './lib/scenario/claimants/scenario-claimant.types';
51
- export * from './lib/scenario/claimants/scenario-claimant.gql';
52
- export * from './lib/scenario/claimants/scenario-claimant.service';
53
- export * from './lib/scenario/receivers/scenario-receiver.types';
54
- export * from './lib/scenario/receivers/scenario-receiver.gql';
55
- export * from './lib/scenario/receivers/scenario-receiver.service';
56
43
  export * from './lib/users/profile.gql';
57
44
  export * from './lib/users/profile.service';
58
45
  export * from './lib/users/profile-details.service';
@@ -68,13 +55,14 @@ export { gqlTyped } from './lib/_common/ast';
68
55
  export * from './lib/api/lr-graphql';
69
56
  export * from './lib/api/query-processor';
70
57
  export * from './lib/api/contact-card2.service';
71
- export * from './lib/api/item2.service';
72
58
  export * from './lib/api/key-exchange2.service';
73
59
  export * from './lib/api/shared-contact-card2.service';
74
60
  export * from './lib/api/lock.service';
61
+ export * from './lib/items2/item2.types';
62
+ export * from './lib/items2/item2.service';
75
63
  export * from './lib/trusted-parties/trusted-party2.service';
76
64
  export * from './lib/trusted-parties/tp-password-reset.service';
77
65
  export * from './lib/trusted-parties/tp-password-reset-user.service';
78
66
  export * from './lib/trusted-parties/tp-password-reset-request.service';
79
67
  export * from './lib/notification/notification.service';
80
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIvb3B0L2F0bGFzc2lhbi9waXBlbGluZXMvYWdlbnQvYnVpbGQvcHJvamVjdHMvY29yZS9zcmMvIiwic291cmNlcyI6WyJwdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYywwQkFBMEIsQ0FBQztBQUV6QyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsZ0NBQWdDLENBQUM7QUFDL0MsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLDRCQUE0QixDQUFDO0FBQzNDLGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsMkJBQTJCLENBQUM7QUFFMUMsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyxvQ0FBb0MsQ0FBQztBQUNuRCxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMseUJBQXlCLENBQUM7QUFFeEMsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLGdDQUFnQyxDQUFDO0FBQy9DLGNBQWMsd0NBQXdDLENBQUM7QUFDdkQsY0FBYyxzQ0FBc0MsQ0FBQztBQUNyRCxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLHVDQUF1QyxDQUFDO0FBRXRELGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsaUNBQWlDLENBQUM7QUFFaEQsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyw2QkFBNkIsQ0FBQztBQUU1QyxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMsdUNBQXVDLENBQUM7QUFFdEQsY0FBYywyQ0FBMkMsQ0FBQztBQUMxRCxjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMsNkNBQTZDLENBQUM7QUFFNUQsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyx1Q0FBdUMsQ0FBQztBQUV0RCxjQUFjLGtEQUFrRCxDQUFDO0FBQ2pFLGNBQWMsZ0RBQWdELENBQUM7QUFDL0QsY0FBYyxvREFBb0QsQ0FBQztBQUVuRSxjQUFjLGtEQUFrRCxDQUFDO0FBQ2pFLGNBQWMsZ0RBQWdELENBQUM7QUFDL0QsY0FBYyxvREFBb0QsQ0FBQztBQUVuRSxjQUFjLGtEQUFrRCxDQUFDO0FBQ2pFLGNBQWMsZ0RBQWdELENBQUM7QUFDL0QsY0FBYyxvREFBb0QsQ0FBQztBQUVuRSxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYyxxQ0FBcUMsQ0FBQztBQUNwRCxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLHdCQUF3QixDQUFDO0FBRXZDLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMseUJBQXlCLENBQUM7QUFFeEMsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBRTdDLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLHdDQUF3QyxDQUFDO0FBQ3ZELGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyw4Q0FBOEMsQ0FBQztBQUM3RCxjQUFjLGlEQUFpRCxDQUFDO0FBQ2hFLGNBQWMsc0RBQXNELENBQUM7QUFDckUsY0FBYyx5REFBeUQsQ0FBQztBQUN4RSxjQUFjLHlDQUF5QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBsci1hdXRoXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9saWIvX2NvbW1vbi9leGNlcHRpb25zJztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvYXBpL2ZpbGUuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hcGkva2V5LWV4Y2hhbmdlLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYXBpL2tleS1leGNoYW5nZS50eXBlcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hcGkva2V5LWV4Y2hhbmdlLmdxbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hcGkvbHItYXBvbGxvLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYXBpL3BlcnNpc3Quc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hcGkvbWVzc2FnZS5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL19jb21tb24vcXVlcmllcy5ncWwnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9hdXRoL2F1dGgudHlwZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYXV0aC9hdXRoLmNvbmZpZyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hdXRoL2xib3Auc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hdXRoL2xpZmUtcmVhZHktYXV0aC5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2F1dGgvcGFzc3dvcmQuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hdXRoL3JlZ2lzdGVyLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYXV0aC90d28tZmFjdG9yLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYXV0aC9pZGxlLnR5cGVzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2F1dGgvaWRsZS5zZXJ2aWNlJztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvY3J5cHRvZ3JhcGh5L2VuY3J5cHRpb24uc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jcnlwdG9ncmFwaHkva2V5LnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY3J5cHRvZ3JhcGh5L2tleS1mYWN0b3J5LnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY3J5cHRvZ3JhcGh5L2tleS1ncmFwaC5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NyeXB0b2dyYXBoeS9rZXktbWV0YS5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NyeXB0b2dyYXBoeS9jcnlwdG9ncmFwaHkudHlwZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY3J5cHRvZ3JhcGh5L3NsaXAzOS5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NyeXB0b2dyYXBoeS93ZWItY3J5cHRvLnNlcnZpY2UnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jYXRlZ29yeS9jYXRlZ29yeS1tZXRhLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY2F0ZWdvcnkvY2F0ZWdvcnkudHlwZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY2F0ZWdvcnkvY2F0ZWdvcnkuZ3FsJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NhdGVnb3J5L2NhdGVnb3J5LnNlcnZpY2UnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9yZWNvcmQvcmVjb3JkLWF0dGFjaG1lbnQuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9yZWNvcmQvcmVjb3JkLnR5cGVzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3JlY29yZC9yZWNvcmQuZ3FsJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3JlY29yZC9yZWNvcmQuc2VydmljZSc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL3JlY29yZC10eXBlL3JlY29yZC10eXBlLnR5cGVzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3JlY29yZC10eXBlL3JlY29yZC10eXBlLnNlcnZpY2UnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi90cnVzdGVkLXBhcnRpZXMvdHJ1c3RlZC1wYXJ0eS50eXBlcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90cnVzdGVkLXBhcnRpZXMvdHJ1c3RlZC1wYXJ0eS5ncWwnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdHJ1c3RlZC1wYXJ0aWVzL3RydXN0ZWQtcGFydHkuc2VydmljZSc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL3NjZW5hcmlvL3NjZW5hcmlvLnR5cGVzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NjZW5hcmlvL3NjZW5hcmlvLmdxbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zY2VuYXJpby9zY2VuYXJpby5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NjZW5hcmlvL3NjZW5hcmlvLXNldHVwLnNlcnZpY2UnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9zY2VuYXJpby9hcHByb3ZhbHMvc2NlbmFyaW8tYXBwcm92YWwudHlwZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2NlbmFyaW8vYXBwcm92YWxzL3NjZW5hcmlvLWFwcHJvdmFsLmdxbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zY2VuYXJpby9hcHByb3ZhbHMvc2NlbmFyaW8tYXBwcm92ZXIuc2VydmljZSc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL3NjZW5hcmlvL2NsYWltYW50cy9zY2VuYXJpby1jbGFpbWFudC50eXBlcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zY2VuYXJpby9jbGFpbWFudHMvc2NlbmFyaW8tY2xhaW1hbnQuZ3FsJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NjZW5hcmlvL2NsYWltYW50cy9zY2VuYXJpby1jbGFpbWFudC5zZXJ2aWNlJztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvc2NlbmFyaW8vcmVjZWl2ZXJzL3NjZW5hcmlvLXJlY2VpdmVyLnR5cGVzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NjZW5hcmlvL3JlY2VpdmVycy9zY2VuYXJpby1yZWNlaXZlci5ncWwnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2NlbmFyaW8vcmVjZWl2ZXJzL3NjZW5hcmlvLXJlY2VpdmVyLnNlcnZpY2UnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi91c2Vycy9wcm9maWxlLmdxbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91c2Vycy9wcm9maWxlLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdXNlcnMvcHJvZmlsZS1kZXRhaWxzLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdXNlcnMvcHJvZmlsZS50eXBlcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91c2Vycy91c2VyLmdxbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91c2Vycy91c2VyLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdXNlcnMvdXNlci50eXBlcyc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpZmUtcmVhZHkuY29uZmlnJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpZmUtcmVhZHkubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3BsYW4vcGxhbi50eXBlcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9wbGFuL3BsYW4uc2VydmljZSc7XG5cbmV4cG9ydCB7IGdxbFR5cGVkIH0gZnJvbSAnLi9saWIvX2NvbW1vbi9hc3QnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9hcGkvbHItZ3JhcGhxbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hcGkvcXVlcnktcHJvY2Vzc29yJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2FwaS9jb250YWN0LWNhcmQyLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYXBpL2l0ZW0yLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYXBpL2tleS1leGNoYW5nZTIuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hcGkvc2hhcmVkLWNvbnRhY3QtY2FyZDIuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hcGkvbG9jay5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RydXN0ZWQtcGFydGllcy90cnVzdGVkLXBhcnR5Mi5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RydXN0ZWQtcGFydGllcy90cC1wYXNzd29yZC1yZXNldC5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RydXN0ZWQtcGFydGllcy90cC1wYXNzd29yZC1yZXNldC11c2VyLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdHJ1c3RlZC1wYXJ0aWVzL3RwLXBhc3N3b3JkLXJlc2V0LXJlcXVlc3Quc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9ub3RpZmljYXRpb24vbm90aWZpY2F0aW9uLnNlcnZpY2UnO1xuIl19
68
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIvb3B0L2F0bGFzc2lhbi9waXBlbGluZXMvYWdlbnQvYnVpbGQvcHJvamVjdHMvY29yZS9zcmMvIiwic291cmNlcyI6WyJwdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYywwQkFBMEIsQ0FBQztBQUV6QyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsZ0NBQWdDLENBQUM7QUFDL0MsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLDRCQUE0QixDQUFDO0FBQzNDLGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsMkJBQTJCLENBQUM7QUFFMUMsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyxvQ0FBb0MsQ0FBQztBQUNuRCxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMseUJBQXlCLENBQUM7QUFFeEMsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLGdDQUFnQyxDQUFDO0FBQy9DLGNBQWMsd0NBQXdDLENBQUM7QUFDdkQsY0FBYyxzQ0FBc0MsQ0FBQztBQUNyRCxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLHVDQUF1QyxDQUFDO0FBRXRELGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsaUNBQWlDLENBQUM7QUFFaEQsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyw2QkFBNkIsQ0FBQztBQUU1QyxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMsdUNBQXVDLENBQUM7QUFFdEQsY0FBYywyQ0FBMkMsQ0FBQztBQUMxRCxjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMsNkNBQTZDLENBQUM7QUFFNUQsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYyx3QkFBd0IsQ0FBQztBQUV2QyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLHlCQUF5QixDQUFDO0FBRXhDLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUU3QyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsd0NBQXdDLENBQUM7QUFDdkQsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyw4Q0FBOEMsQ0FBQztBQUM3RCxjQUFjLGlEQUFpRCxDQUFDO0FBQ2hFLGNBQWMsc0RBQXNELENBQUM7QUFDckUsY0FBYyx5REFBeUQsQ0FBQztBQUN4RSxjQUFjLHlDQUF5QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBsci1hdXRoXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9saWIvX2NvbW1vbi9leGNlcHRpb25zJztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvYXBpL2ZpbGUuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hcGkva2V5LWV4Y2hhbmdlLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYXBpL2tleS1leGNoYW5nZS50eXBlcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hcGkva2V5LWV4Y2hhbmdlLmdxbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hcGkvbHItYXBvbGxvLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYXBpL3BlcnNpc3Quc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hcGkvbWVzc2FnZS5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL19jb21tb24vcXVlcmllcy5ncWwnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9hdXRoL2F1dGgudHlwZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYXV0aC9hdXRoLmNvbmZpZyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hdXRoL2xib3Auc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hdXRoL2xpZmUtcmVhZHktYXV0aC5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2F1dGgvcGFzc3dvcmQuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hdXRoL3JlZ2lzdGVyLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYXV0aC90d28tZmFjdG9yLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYXV0aC9pZGxlLnR5cGVzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2F1dGgvaWRsZS5zZXJ2aWNlJztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvY3J5cHRvZ3JhcGh5L2VuY3J5cHRpb24uc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jcnlwdG9ncmFwaHkva2V5LnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY3J5cHRvZ3JhcGh5L2tleS1mYWN0b3J5LnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY3J5cHRvZ3JhcGh5L2tleS1ncmFwaC5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NyeXB0b2dyYXBoeS9rZXktbWV0YS5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NyeXB0b2dyYXBoeS9jcnlwdG9ncmFwaHkudHlwZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY3J5cHRvZ3JhcGh5L3NsaXAzOS5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NyeXB0b2dyYXBoeS93ZWItY3J5cHRvLnNlcnZpY2UnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jYXRlZ29yeS9jYXRlZ29yeS1tZXRhLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY2F0ZWdvcnkvY2F0ZWdvcnkudHlwZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY2F0ZWdvcnkvY2F0ZWdvcnkuZ3FsJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NhdGVnb3J5L2NhdGVnb3J5LnNlcnZpY2UnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9yZWNvcmQvcmVjb3JkLWF0dGFjaG1lbnQuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9yZWNvcmQvcmVjb3JkLnR5cGVzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3JlY29yZC9yZWNvcmQuZ3FsJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3JlY29yZC9yZWNvcmQuc2VydmljZSc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL3JlY29yZC10eXBlL3JlY29yZC10eXBlLnR5cGVzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3JlY29yZC10eXBlL3JlY29yZC10eXBlLnNlcnZpY2UnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi90cnVzdGVkLXBhcnRpZXMvdHJ1c3RlZC1wYXJ0eS50eXBlcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90cnVzdGVkLXBhcnRpZXMvdHJ1c3RlZC1wYXJ0eS5ncWwnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdHJ1c3RlZC1wYXJ0aWVzL3RydXN0ZWQtcGFydHkuc2VydmljZSc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL3VzZXJzL3Byb2ZpbGUuZ3FsJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3VzZXJzL3Byb2ZpbGUuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91c2Vycy9wcm9maWxlLWRldGFpbHMuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91c2Vycy9wcm9maWxlLnR5cGVzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3VzZXJzL3VzZXIuZ3FsJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3VzZXJzL3VzZXIuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91c2Vycy91c2VyLnR5cGVzJztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvbGlmZS1yZWFkeS5jb25maWcnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbGlmZS1yZWFkeS5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcGxhbi9wbGFuLnR5cGVzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3BsYW4vcGxhbi5zZXJ2aWNlJztcblxuZXhwb3J0IHsgZ3FsVHlwZWQgfSBmcm9tICcuL2xpYi9fY29tbW9uL2FzdCc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL2FwaS9sci1ncmFwaHFsJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2FwaS9xdWVyeS1wcm9jZXNzb3InO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYXBpL2NvbnRhY3QtY2FyZDIuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hcGkva2V5LWV4Y2hhbmdlMi5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2FwaS9zaGFyZWQtY29udGFjdC1jYXJkMi5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2FwaS9sb2NrLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvaXRlbXMyL2l0ZW0yLnR5cGVzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2l0ZW1zMi9pdGVtMi5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RydXN0ZWQtcGFydGllcy90cnVzdGVkLXBhcnR5Mi5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RydXN0ZWQtcGFydGllcy90cC1wYXNzd29yZC1yZXNldC5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RydXN0ZWQtcGFydGllcy90cC1wYXNzd29yZC1yZXNldC11c2VyLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdHJ1c3RlZC1wYXJ0aWVzL3RwLXBhc3N3b3JkLXJlc2V0LXJlcXVlc3Quc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9ub3RpZmljYXRpb24vbm90aWZpY2F0aW9uLnNlcnZpY2UnO1xuIl19