@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.
Files changed (84) hide show
  1. package/bundles/lifeready-core.umd.js +7390 -8456
  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/scenario/scenario.constants.js +2 -0
  17. package/esm2015/lib/scenario/scenario.controller.js +34 -0
  18. package/esm2015/lib/scenario/scenario.gql.js +35 -331
  19. package/esm2015/lib/scenario/scenario.gql.private.js +198 -0
  20. package/esm2015/lib/scenario/scenario.service.js +420 -493
  21. package/esm2015/lib/scenario/scenario.types.js +1 -64
  22. package/esm2015/lib/trusted-parties/tp-assembly.gql.private.js +22 -0
  23. package/esm2015/lib/trusted-parties/tp-assembly.js +362 -0
  24. package/esm2015/lib/trusted-parties/tp-assembly.types.js +1 -0
  25. package/esm2015/lib/trusted-parties/tp-password-reset-request.service.js +4 -3
  26. package/esm2015/lib/trusted-parties/tp-password-reset.controller.js +34 -0
  27. package/esm2015/lib/trusted-parties/tp-password-reset.gql.js +5 -1
  28. package/esm2015/lib/trusted-parties/tp-password-reset.service.js +36 -240
  29. package/esm2015/lib/trusted-parties/trusted-party2.service.js +3 -3
  30. package/esm2015/lifeready-core.js +6 -3
  31. package/esm2015/public-api.js +6 -15
  32. package/fesm2015/lifeready-core.js +6127 -6909
  33. package/fesm2015/lifeready-core.js.map +1 -1
  34. package/lib/_common/utils.d.ts +6 -0
  35. package/lib/api/lock.service.d.ts +12 -3
  36. package/lib/api/lr-graphql/lr-merged-mutation.d.ts +1 -0
  37. package/lib/api/query-processor/query-processor.service.d.ts +1 -1
  38. package/lib/api/types/lr-graphql.types.d.ts +107 -2
  39. package/lib/auth/life-ready-auth.service.d.ts +3 -1
  40. package/lib/cryptography/key-graph.service.d.ts +9 -1
  41. package/lib/{api → items2}/item2.gql.d.ts +28 -1
  42. package/lib/items2/item2.service.d.ts +203 -0
  43. package/lib/items2/item2.types.d.ts +70 -0
  44. package/lib/scenario/scenario.constants.d.ts +1 -0
  45. package/lib/scenario/scenario.controller.d.ts +10 -0
  46. package/lib/scenario/scenario.gql.d.ts +52 -24
  47. package/lib/scenario/scenario.gql.private.d.ts +16 -0
  48. package/lib/scenario/scenario.service.d.ts +229 -54
  49. package/lib/scenario/scenario.types.d.ts +47 -214
  50. package/lib/trusted-parties/tp-assembly.d.ts +177 -0
  51. package/lib/trusted-parties/tp-assembly.gql.private.d.ts +5 -0
  52. package/lib/trusted-parties/tp-assembly.types.d.ts +38 -0
  53. package/lib/trusted-parties/tp-password-reset-request.service.d.ts +3 -3
  54. package/lib/trusted-parties/tp-password-reset.controller.d.ts +10 -0
  55. package/lib/trusted-parties/tp-password-reset.gql.d.ts +5 -0
  56. package/lib/trusted-parties/tp-password-reset.service.d.ts +99 -41
  57. package/lib/trusted-parties/trusted-party2.service.d.ts +1 -1
  58. package/lifeready-core.d.ts +5 -2
  59. package/lifeready-core.metadata.json +1 -1
  60. package/package.json +1 -1
  61. package/public-api.d.ts +5 -14
  62. package/esm2015/lib/api/item2.gql.js +0 -110
  63. package/esm2015/lib/api/item2.service.js +0 -311
  64. package/esm2015/lib/scenario/approvals/scenario-approval.gql.js +0 -105
  65. package/esm2015/lib/scenario/approvals/scenario-approval.types.js +0 -1
  66. package/esm2015/lib/scenario/approvals/scenario-approver.service.js +0 -300
  67. package/esm2015/lib/scenario/claimants/scenario-claimant.gql.js +0 -52
  68. package/esm2015/lib/scenario/claimants/scenario-claimant.service.js +0 -97
  69. package/esm2015/lib/scenario/claimants/scenario-claimant.types.js +0 -1
  70. package/esm2015/lib/scenario/receivers/scenario-receiver.gql.js +0 -150
  71. package/esm2015/lib/scenario/receivers/scenario-receiver.service.js +0 -229
  72. package/esm2015/lib/scenario/receivers/scenario-receiver.types.js +0 -1
  73. package/esm2015/lib/scenario/scenario-setup.service.js +0 -269
  74. package/lib/api/item2.service.d.ts +0 -177
  75. package/lib/scenario/approvals/scenario-approval.gql.d.ts +0 -7
  76. package/lib/scenario/approvals/scenario-approval.types.d.ts +0 -63
  77. package/lib/scenario/approvals/scenario-approver.service.d.ts +0 -32
  78. package/lib/scenario/claimants/scenario-claimant.gql.d.ts +0 -5
  79. package/lib/scenario/claimants/scenario-claimant.service.d.ts +0 -17
  80. package/lib/scenario/claimants/scenario-claimant.types.d.ts +0 -18
  81. package/lib/scenario/receivers/scenario-receiver.gql.d.ts +0 -8
  82. package/lib/scenario/receivers/scenario-receiver.service.d.ts +0 -30
  83. package/lib/scenario/receivers/scenario-receiver.types.d.ts +0 -54
  84. package/lib/scenario/scenario-setup.service.d.ts +0 -22
@@ -1,269 +0,0 @@
1
- import { __awaiter } from "tslib";
2
- import { Injectable } from '@angular/core';
3
- import { ScenarioApproverService } from './approvals/scenario-approver.service';
4
- import { ScenarioClaimantService } from './claimants/scenario-claimant.service';
5
- import { ScenarioReceiverService } from './receivers/scenario-receiver.service';
6
- import { ScenarioService } from './scenario.service';
7
- import * as i0 from "@angular/core";
8
- import * as i1 from "./scenario.service";
9
- import * as i2 from "./claimants/scenario-claimant.service";
10
- import * as i3 from "./approvals/scenario-approver.service";
11
- import * as i4 from "./receivers/scenario-receiver.service";
12
- export class ScenarioSetupService {
13
- constructor(scenarioService, scenarioClaimantService, scenarioApproverService, scenarioReceiverService) {
14
- this.scenarioService = scenarioService;
15
- this.scenarioClaimantService = scenarioClaimantService;
16
- this.scenarioApproverService = scenarioApproverService;
17
- this.scenarioReceiverService = scenarioReceiverService;
18
- }
19
- setupScenario(newScenario) {
20
- return __awaiter(this, void 0, void 0, function* () {
21
- const scenarioId = yield this.scenarioService.createScenario({
22
- plainSubjectCipherData: {
23
- event: newScenario.event,
24
- name: newScenario.name,
25
- },
26
- });
27
- try {
28
- yield Promise.all(newScenario.claimants.map((x) => this.updateClaimant(scenarioId, newScenario.event, x)));
29
- const scenario = yield this.scenarioService.getScenario(scenarioId);
30
- if (newScenario.approvalGroups.length) {
31
- const approvalGroups = {
32
- scenarioId,
33
- keyId: scenario.keyId,
34
- event: scenario.event,
35
- singleReject: false,
36
- quorum: 1,
37
- plainAssemblyCipherData: null,
38
- approvalGroups: newScenario.approvalGroups.map((x) => ({
39
- quorum: x.quorum,
40
- singleReject: x.singleReject,
41
- plainSubAssemblyCipherData: { name: x.name },
42
- approvers: x.approvers.map((y) => ({
43
- trustedPartyId: y.trustedPartyId,
44
- trustedPartySharedKeyId: y.trustedPartySharedKeyId,
45
- plainSharedCipherData: {
46
- message: y.message,
47
- event: newScenario.event,
48
- },
49
- })),
50
- })),
51
- };
52
- scenario.assemblyKeyId = yield this.scenarioApproverService.createScenarioApproverAssembly(approvalGroups);
53
- }
54
- yield Promise.all(newScenario.receivers.map((x) => this.updateReceiver(scenarioId, scenario.assemblyKeyId, newScenario.event, x)));
55
- }
56
- catch (e) {
57
- return { scenarioId, error: e };
58
- }
59
- return { scenarioId };
60
- });
61
- }
62
- updateScenario(updateScenario) {
63
- return __awaiter(this, void 0, void 0, function* () {
64
- const params = {
65
- scenarioId: updateScenario.scenarioId,
66
- keyId: updateScenario.keyId,
67
- plainSubjectCipherData: {
68
- event: updateScenario.event,
69
- name: updateScenario.name,
70
- },
71
- };
72
- yield this.scenarioService.updateScenario(params);
73
- yield Promise.all(updateScenario.claimants.map((x) => this.updateClaimant(updateScenario.scenarioId, updateScenario.event, x)));
74
- yield Promise.all(updateScenario.deletedClaimantIds.map((x) => this.scenarioClaimantService.deleteClaimant(x)));
75
- const assemblyKeyId = yield this.updateApprovalGroups(updateScenario);
76
- yield Promise.all(updateScenario.receivers.map((x) => this.updateReceiver(updateScenario.scenarioId, assemblyKeyId, updateScenario.event, x)));
77
- yield Promise.all(updateScenario.deletedReceiverIds.map((x) => this.scenarioReceiverService.deleteReceiver(x)));
78
- });
79
- }
80
- updateClaimant(scenarioId, event, claimant) {
81
- return __awaiter(this, void 0, void 0, function* () {
82
- if (claimant.claimantId) {
83
- yield this.scenarioClaimantService.updateClaimant({
84
- id: claimant.claimantId,
85
- keyId: claimant.keyId,
86
- plainSharedCipherData: { message: claimant.message, event },
87
- });
88
- }
89
- else {
90
- yield this.scenarioClaimantService.addClaimant({
91
- scenarioId,
92
- trustedPartyId: claimant.trustedPartyId,
93
- trustedPartySharedKeyId: claimant.trustedPartySharedKeyId,
94
- plainSharedCipherData: { message: claimant.message, event },
95
- });
96
- }
97
- });
98
- }
99
- updateApprovalGroups(updateScenario) {
100
- return __awaiter(this, void 0, void 0, function* () {
101
- if (updateScenario.assemblyKeyId) {
102
- if (updateScenario.approvalGroups.length) {
103
- const approvalGroups = {
104
- scenarioId: updateScenario.scenarioId,
105
- assemblyKeyId: updateScenario.assemblyKeyId,
106
- singleReject: false,
107
- quorum: 1,
108
- approvalGroups: updateScenario.approvalGroups.map((x) => ({
109
- subAssemblyId: x.subAssemblyId,
110
- quorum: x.quorum,
111
- singleReject: x.singleReject,
112
- plainSubAssemblyCipherData: { name: x.name },
113
- approvers: x.approvers.map((y) => ({
114
- approverId: y.approverId,
115
- keyId: y.keyId,
116
- trustedPartyId: y.trustedPartyId,
117
- trustedPartySharedKeyId: y.trustedPartySharedKeyId,
118
- plainSharedCipherData: {
119
- message: y.message,
120
- event: updateScenario.event,
121
- },
122
- })),
123
- deletedApproverIds: x.deletedApproverIds,
124
- })),
125
- deletedGroupIds: updateScenario.deletedGroupIds,
126
- };
127
- yield this.scenarioApproverService.updateScenarioApproverAssembly(approvalGroups);
128
- return updateScenario.assemblyKeyId;
129
- }
130
- else {
131
- const { receivers } = yield this.scenarioService.getScenario(updateScenario.scenarioId);
132
- yield this.scenarioApproverService.deleteScenarioApproverAssembly(updateScenario.scenarioId, updateScenario.event, receivers);
133
- return null;
134
- }
135
- // update or delete
136
- }
137
- else if (updateScenario.approvalGroups.length) {
138
- const { receivers } = yield this.scenarioService.getScenario(updateScenario.scenarioId);
139
- const approvalGroups = {
140
- scenarioId: updateScenario.scenarioId,
141
- keyId: updateScenario.keyId,
142
- event: updateScenario.event,
143
- singleReject: false,
144
- quorum: 1,
145
- approvalGroups: updateScenario.approvalGroups.map((x) => ({
146
- quorum: x.quorum,
147
- singleReject: x.singleReject,
148
- plainSubAssemblyCipherData: { name: x.name },
149
- approvers: x.approvers.map((y) => ({
150
- trustedPartyId: y.trustedPartyId,
151
- trustedPartySharedKeyId: y.trustedPartySharedKeyId,
152
- plainSharedCipherData: {
153
- message: y.message,
154
- event: updateScenario.event,
155
- },
156
- })),
157
- })),
158
- receivers,
159
- };
160
- return yield this.scenarioApproverService.createScenarioApproverAssembly(approvalGroups);
161
- }
162
- return null;
163
- });
164
- }
165
- updateReceiver(scenarioId, assemblyKeyId, event, receiver) {
166
- return __awaiter(this, void 0, void 0, function* () {
167
- let receiverId = receiver.receiverId;
168
- // Currently deleting all receivers below assembly logic.
169
- if (receiverId) {
170
- yield this.scenarioReceiverService.updateReceiver({
171
- id: receiver.receiverId,
172
- keyId: receiver.keyId,
173
- plainSharedCipherData: { message: receiver.message, event },
174
- });
175
- }
176
- else {
177
- const newReceiver = {
178
- scenarioId,
179
- trustedPartyId: receiver.trustedPartyId,
180
- trustedPartySharedKeyId: receiver.trustedPartySharedKeyId,
181
- plainSharedCipherData: { message: receiver.message, event },
182
- };
183
- receiverId = yield this.scenarioReceiverService.addReceiver(newReceiver);
184
- }
185
- const loadedReceiver = yield this.scenarioReceiverService.getReceiver(receiverId);
186
- yield this.updateReceiverItems(scenarioId, assemblyKeyId, loadedReceiver, receiver.permissions);
187
- });
188
- }
189
- updateReceiverItems(scenarioId, assemblyKeyId, receiver, permissions) {
190
- return __awaiter(this, void 0, void 0, function* () {
191
- permissions = permissions || {};
192
- permissions.categories = permissions.categories || [];
193
- permissions.records = permissions.records || [];
194
- yield Promise.all(permissions.categories
195
- .filter((x) => !receiver.categories.some((y) => y.category.id === x.categoryId))
196
- .map((x) => __awaiter(this, void 0, void 0, function* () {
197
- const params = {
198
- scenarioId,
199
- assemblyKeyId,
200
- receiverId: receiver.id,
201
- receiverKeyId: receiver.keyId,
202
- accessRole: x.accessLevel,
203
- categoryId: x.categoryId,
204
- };
205
- yield this.scenarioReceiverService.addReceiverCategory(params);
206
- })));
207
- yield Promise.all(permissions.records
208
- .filter((x) => !receiver.records.some((y) => y.record.id === x.recordId))
209
- .map((x) => __awaiter(this, void 0, void 0, function* () {
210
- const params = {
211
- scenarioId,
212
- assemblyKeyId,
213
- receiverId: receiver.id,
214
- receiverKeyId: receiver.keyId,
215
- accessRole: x.accessLevel,
216
- recordId: x.recordId,
217
- };
218
- yield this.scenarioReceiverService.addReceiverRecord(params);
219
- })));
220
- yield Promise.all(permissions.categories
221
- .map((x) => ({
222
- accessLevel: x.accessLevel,
223
- category: receiver.categories.find((y) => y.category.id === x.categoryId),
224
- }))
225
- .filter((x) => x.category)
226
- .map((x) => __awaiter(this, void 0, void 0, function* () {
227
- const params = {
228
- id: x.category.id,
229
- keyId: x.category.keyId,
230
- accessRole: x.accessLevel,
231
- };
232
- yield this.scenarioReceiverService.updateReceiverItem(params);
233
- })));
234
- yield Promise.all(permissions.records
235
- .map((x) => ({
236
- accessLevel: x.accessLevel,
237
- record: receiver.records.find((y) => y.record.id === x.recordId),
238
- }))
239
- .filter((x) => x.record)
240
- .map((x) => __awaiter(this, void 0, void 0, function* () {
241
- const params = {
242
- id: x.record.id,
243
- keyId: x.record.keyId,
244
- accessRole: x.accessLevel,
245
- };
246
- yield this.scenarioReceiverService.updateReceiverItem(params);
247
- })));
248
- yield Promise.all(receiver.categories
249
- .filter((x) => !permissions.categories.some((y) => y.categoryId === x.category.id))
250
- .map((x) => this.scenarioReceiverService.deleteReceiverItem(x.id)));
251
- yield Promise.all(receiver.records
252
- .filter((x) => !permissions.records.some((y) => y.recordId === x.record.id))
253
- .map((x) => this.scenarioReceiverService.deleteReceiverItem(x.id)));
254
- });
255
- }
256
- }
257
- ScenarioSetupService.ɵprov = i0.ɵɵdefineInjectable({ factory: function ScenarioSetupService_Factory() { return new ScenarioSetupService(i0.ɵɵinject(i1.ScenarioService), i0.ɵɵinject(i2.ScenarioClaimantService), i0.ɵɵinject(i3.ScenarioApproverService), i0.ɵɵinject(i4.ScenarioReceiverService)); }, token: ScenarioSetupService, providedIn: "root" });
258
- ScenarioSetupService.decorators = [
259
- { type: Injectable, args: [{
260
- providedIn: 'root',
261
- },] }
262
- ];
263
- ScenarioSetupService.ctorParameters = () => [
264
- { type: ScenarioService },
265
- { type: ScenarioClaimantService },
266
- { type: ScenarioApproverService },
267
- { type: ScenarioReceiverService }
268
- ];
269
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scenario-setup.service.js","sourceRoot":"/opt/atlassian/pipelines/agent/build/projects/core/src/","sources":["lib/scenario/scenario-setup.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { LrException } from './../_common/exceptions';\nimport { Injectable } from '@angular/core';\nimport { PreparedPermissions } from './../api/key-exchange.types';\nimport {\n  CreateScenarioApprovalGroups,\n  UpdateScenarioApprovalGroups,\n} from './approvals/scenario-approval.types';\nimport { ScenarioApproverService } from './approvals/scenario-approver.service';\nimport { ScenarioClaimantService } from './claimants/scenario-claimant.service';\nimport { ScenarioReceiverService } from './receivers/scenario-receiver.service';\nimport {\n  Receiver,\n  UpdateScenarioReceiverItemInput,\n} from './receivers/scenario-receiver.types';\nimport { ScenarioService } from './scenario.service';\nimport {\n  NewScenario,\n  UpdatedScenarioClaimant,\n  UpdatedScenarioReceiver,\n  UpdateScenario,\n} from './scenario.types';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class ScenarioSetupService {\n  constructor(\n    private scenarioService: ScenarioService,\n    private scenarioClaimantService: ScenarioClaimantService,\n    private scenarioApproverService: ScenarioApproverService,\n    private scenarioReceiverService: ScenarioReceiverService\n  ) {}\n\n  public async setupScenario(\n    newScenario: NewScenario\n  ): Promise<{ scenarioId: string; error?: LrException }> {\n    const scenarioId = await this.scenarioService.createScenario({\n      plainSubjectCipherData: {\n        event: newScenario.event,\n        name: newScenario.name,\n      },\n    });\n\n    try {\n      await Promise.all(\n        newScenario.claimants.map((x) =>\n          this.updateClaimant(scenarioId, newScenario.event, x)\n        )\n      );\n\n      const scenario = await this.scenarioService.getScenario(scenarioId);\n      if (newScenario.approvalGroups.length) {\n        const approvalGroups: CreateScenarioApprovalGroups = {\n          scenarioId,\n          keyId: scenario.keyId,\n          event: scenario.event,\n          singleReject: false,\n          quorum: 1,\n          plainAssemblyCipherData: null,\n\n          approvalGroups: newScenario.approvalGroups.map((x) => ({\n            quorum: x.quorum,\n            singleReject: x.singleReject,\n            plainSubAssemblyCipherData: { name: x.name },\n            approvers: x.approvers.map((y) => ({\n              trustedPartyId: y.trustedPartyId,\n              trustedPartySharedKeyId: y.trustedPartySharedKeyId,\n              plainSharedCipherData: {\n                message: y.message,\n                event: newScenario.event,\n              },\n            })),\n          })),\n        };\n        scenario.assemblyKeyId = await this.scenarioApproverService.createScenarioApproverAssembly(\n          approvalGroups\n        );\n      }\n      await Promise.all(\n        newScenario.receivers.map((x) =>\n          this.updateReceiver(\n            scenarioId,\n            scenario.assemblyKeyId,\n            newScenario.event,\n            x\n          )\n        )\n      );\n    } catch (e) {\n      return { scenarioId, error: e };\n    }\n    return { scenarioId };\n  }\n\n  public async updateScenario(updateScenario: UpdateScenario): Promise<void> {\n    const params = {\n      scenarioId: updateScenario.scenarioId,\n      keyId: updateScenario.keyId,\n      plainSubjectCipherData: {\n        event: updateScenario.event,\n        name: updateScenario.name,\n      },\n    };\n    await this.scenarioService.updateScenario(params);\n\n    await Promise.all(\n      updateScenario.claimants.map((x) =>\n        this.updateClaimant(updateScenario.scenarioId, updateScenario.event, x)\n      )\n    );\n    await Promise.all(\n      updateScenario.deletedClaimantIds.map((x) =>\n        this.scenarioClaimantService.deleteClaimant(x)\n      )\n    );\n\n    const assemblyKeyId = await this.updateApprovalGroups(updateScenario);\n\n    await Promise.all(\n      updateScenario.receivers.map((x) =>\n        this.updateReceiver(\n          updateScenario.scenarioId,\n          assemblyKeyId,\n          updateScenario.event,\n          x\n        )\n      )\n    );\n    await Promise.all(\n      updateScenario.deletedReceiverIds.map((x) =>\n        this.scenarioReceiverService.deleteReceiver(x)\n      )\n    );\n  }\n\n  private async updateClaimant(\n    scenarioId: string,\n    event: string,\n    claimant: UpdatedScenarioClaimant\n  ) {\n    if (claimant.claimantId) {\n      await this.scenarioClaimantService.updateClaimant({\n        id: claimant.claimantId,\n        keyId: claimant.keyId,\n        plainSharedCipherData: { message: claimant.message, event },\n      });\n    } else {\n      await this.scenarioClaimantService.addClaimant({\n        scenarioId,\n        trustedPartyId: claimant.trustedPartyId,\n        trustedPartySharedKeyId: claimant.trustedPartySharedKeyId,\n        plainSharedCipherData: { message: claimant.message, event },\n      });\n    }\n  }\n\n  private async updateApprovalGroups(\n    updateScenario: UpdateScenario\n  ): Promise<string> {\n    if (updateScenario.assemblyKeyId) {\n      if (updateScenario.approvalGroups.length) {\n        const approvalGroups: UpdateScenarioApprovalGroups = {\n          scenarioId: updateScenario.scenarioId,\n          assemblyKeyId: updateScenario.assemblyKeyId,\n\n          singleReject: false,\n          quorum: 1,\n\n          approvalGroups: updateScenario.approvalGroups.map((x) => ({\n            subAssemblyId: x.subAssemblyId,\n            quorum: x.quorum,\n            singleReject: x.singleReject,\n            plainSubAssemblyCipherData: { name: x.name },\n            approvers: x.approvers.map((y) => ({\n              approverId: y.approverId,\n              keyId: y.keyId,\n              trustedPartyId: y.trustedPartyId,\n              trustedPartySharedKeyId: y.trustedPartySharedKeyId,\n              plainSharedCipherData: {\n                message: y.message,\n                event: updateScenario.event,\n              },\n            })),\n            deletedApproverIds: x.deletedApproverIds,\n          })),\n          deletedGroupIds: updateScenario.deletedGroupIds,\n        };\n        await this.scenarioApproverService.updateScenarioApproverAssembly(\n          approvalGroups\n        );\n        return updateScenario.assemblyKeyId;\n      } else {\n        const { receivers } = await this.scenarioService.getScenario(\n          updateScenario.scenarioId\n        );\n        await this.scenarioApproverService.deleteScenarioApproverAssembly(\n          updateScenario.scenarioId,\n          updateScenario.event,\n          receivers\n        );\n        return null;\n      }\n      // update or delete\n    } else if (updateScenario.approvalGroups.length) {\n      const { receivers } = await this.scenarioService.getScenario(\n        updateScenario.scenarioId\n      );\n\n      const approvalGroups: CreateScenarioApprovalGroups = {\n        scenarioId: updateScenario.scenarioId,\n        keyId: updateScenario.keyId,\n        event: updateScenario.event,\n        singleReject: false,\n        quorum: 1,\n        approvalGroups: updateScenario.approvalGroups.map((x) => ({\n          quorum: x.quorum,\n          singleReject: x.singleReject,\n          plainSubAssemblyCipherData: { name: x.name },\n          approvers: x.approvers.map((y) => ({\n            trustedPartyId: y.trustedPartyId,\n            trustedPartySharedKeyId: y.trustedPartySharedKeyId,\n            plainSharedCipherData: {\n              message: y.message,\n              event: updateScenario.event,\n            },\n          })),\n        })),\n        receivers,\n      };\n      return await this.scenarioApproverService.createScenarioApproverAssembly(\n        approvalGroups\n      );\n    }\n    return null;\n  }\n\n  private async updateReceiver(\n    scenarioId: string,\n    assemblyKeyId: string,\n    event: string,\n    receiver: UpdatedScenarioReceiver\n  ) {\n    let receiverId = receiver.receiverId;\n\n    // Currently deleting all receivers below assembly logic.\n    if (receiverId) {\n      await this.scenarioReceiverService.updateReceiver({\n        id: receiver.receiverId,\n        keyId: receiver.keyId,\n        plainSharedCipherData: { message: receiver.message, event },\n      });\n    } else {\n      const newReceiver = {\n        scenarioId,\n        trustedPartyId: receiver.trustedPartyId,\n        trustedPartySharedKeyId: receiver.trustedPartySharedKeyId,\n        plainSharedCipherData: { message: receiver.message, event },\n      };\n      receiverId = await this.scenarioReceiverService.addReceiver(newReceiver);\n    }\n    const loadedReceiver = await this.scenarioReceiverService.getReceiver(\n      receiverId\n    );\n    await this.updateReceiverItems(\n      scenarioId,\n      assemblyKeyId,\n      loadedReceiver,\n      receiver.permissions\n    );\n  }\n\n  private async updateReceiverItems(\n    scenarioId: string,\n    assemblyKeyId: string,\n    receiver: Receiver,\n    permissions: PreparedPermissions\n  ) {\n    permissions = permissions || {};\n    permissions.categories = permissions.categories || [];\n    permissions.records = permissions.records || [];\n\n    await Promise.all(\n      permissions.categories\n        .filter(\n          (x) =>\n            !receiver.categories.some((y) => y.category.id === x.categoryId)\n        )\n        .map(async (x) => {\n          const params = {\n            scenarioId,\n            assemblyKeyId,\n            receiverId: receiver.id,\n            receiverKeyId: receiver.keyId,\n            accessRole: x.accessLevel,\n            categoryId: x.categoryId,\n          };\n          await this.scenarioReceiverService.addReceiverCategory(params);\n        })\n    );\n    await Promise.all(\n      permissions.records\n        .filter(\n          (x) => !receiver.records.some((y) => y.record.id === x.recordId)\n        )\n        .map(async (x) => {\n          const params = {\n            scenarioId,\n            assemblyKeyId,\n            receiverId: receiver.id,\n            receiverKeyId: receiver.keyId,\n            accessRole: x.accessLevel,\n            recordId: x.recordId,\n          };\n          await this.scenarioReceiverService.addReceiverRecord(params);\n        })\n    );\n\n    await Promise.all(\n      permissions.categories\n        .map((x) => ({\n          accessLevel: x.accessLevel,\n          category: receiver.categories.find(\n            (y) => y.category.id === x.categoryId\n          ),\n        }))\n        .filter((x) => x.category)\n        .map(async (x) => {\n          const params: UpdateScenarioReceiverItemInput = {\n            id: x.category.id,\n            keyId: x.category.keyId,\n            accessRole: x.accessLevel,\n          };\n          await this.scenarioReceiverService.updateReceiverItem(params);\n        })\n    );\n    await Promise.all(\n      permissions.records\n        .map((x) => ({\n          accessLevel: x.accessLevel,\n          record: receiver.records.find((y) => y.record.id === x.recordId),\n        }))\n        .filter((x) => x.record)\n        .map(async (x) => {\n          const params: UpdateScenarioReceiverItemInput = {\n            id: x.record.id,\n            keyId: x.record.keyId,\n            accessRole: x.accessLevel,\n          };\n          await this.scenarioReceiverService.updateReceiverItem(params);\n        })\n    );\n\n    await Promise.all(\n      receiver.categories\n        .filter(\n          (x) =>\n            !permissions.categories.some((y) => y.categoryId === x.category.id)\n        )\n        .map((x) => this.scenarioReceiverService.deleteReceiverItem(x.id))\n    );\n    await Promise.all(\n      receiver.records\n        .filter(\n          (x) => !permissions.records.some((y) => y.recordId === x.record.id)\n        )\n        .map((x) => this.scenarioReceiverService.deleteReceiverItem(x.id))\n    );\n  }\n}\n"]}
@@ -1,177 +0,0 @@
1
- import { Injector, NgZone } from '@angular/core';
2
- import { JWK } from 'node-jose';
3
- import { KeyFactoryService } from '../cryptography/key-factory.service';
4
- import { KeyGraphService } from '../cryptography/key-graph.service';
5
- import { KeyMetaService } from '../cryptography/key-meta.service';
6
- import { KeyService } from '../cryptography/key.service';
7
- import { FileService } from './file.service';
8
- import { LrMutation, LrService } from './lr-graphql';
9
- import { CreateDirectoryMutation, DeleteDirectoryMutation, CreateFileMutation, DeleteFileMutation, UpdateFileMutation, UpdateDirectoryMutation, ArchiveDirectoryMutation, UnarchiveDirectoryMutation } from './item2.gql';
10
- import { ID, LrRelayIdInput } from './types';
11
- export declare enum DirectoryLinkType {
12
- HARD = "HARD"
13
- }
14
- export interface ParentDirectoryOptions {
15
- directoryId: LrRelayIdInput;
16
- wrappingKeyId?: LrRelayIdInput;
17
- linkType?: DirectoryLinkType.HARD;
18
- }
19
- export interface ParentRootDirectoryInput {
20
- wrappedKey: string;
21
- wrappingKeyId: LrRelayIdInput;
22
- }
23
- export interface ParentDirectoryInputBase {
24
- directoryId: LrRelayIdInput;
25
- wrappingKeyId: LrRelayIdInput;
26
- linkType?: DirectoryLinkType.HARD;
27
- }
28
- export interface ParentDirectoryInput extends ParentDirectoryInputBase {
29
- wrappedKey: string;
30
- }
31
- export interface FileParentDirectoryInput extends ParentDirectoryInputBase {
32
- wrappedFileKey: string;
33
- }
34
- export interface DownloadFileContentOptions {
35
- fileStateNodeId: LrRelayIdInput;
36
- fileStateKeyId?: LrRelayIdInput;
37
- }
38
- export interface CommonDirectoryOptions {
39
- plainMetaJson?: any;
40
- cipherMetaClearJson?: any;
41
- }
42
- export interface CreateDirectoryOptions extends CommonDirectoryOptions {
43
- asRootDirectory?: boolean;
44
- parentDirectories?: ParentDirectoryOptions[];
45
- }
46
- export interface UpdateDirectoryOptions extends CommonDirectoryOptions {
47
- directoryId: LrRelayIdInput;
48
- directoryKeyId?: LrRelayIdInput;
49
- }
50
- export interface CommonFileOptions {
51
- plainMetaJson?: any;
52
- cipherMetaClearJson?: any;
53
- file?: File;
54
- upload?: (cipherFileContent: string) => Promise<string>;
55
- }
56
- export interface CreateFileOptions extends CommonFileOptions {
57
- parentDirectories: ParentDirectoryOptions[];
58
- }
59
- export interface UpdateFileOptions extends CommonFileOptions {
60
- fileId: LrRelayIdInput;
61
- fileKeyId?: LrRelayIdInput;
62
- }
63
- interface ChangeItemParentsOptions {
64
- parentsToRemove: LrRelayIdInput[];
65
- parentsToAdd: ParentDirectoryOptions[];
66
- }
67
- export interface ChangeDirectoryParentsOptions extends ChangeItemParentsOptions {
68
- directoryId: LrRelayIdInput;
69
- directoryKeyId?: LrRelayIdInput;
70
- }
71
- export interface ChangeFileParentsOptions extends ChangeItemParentsOptions {
72
- fileId: LrRelayIdInput;
73
- fileKeyId?: LrRelayIdInput;
74
- }
75
- export declare class Item2Service extends LrService {
76
- private ngZone;
77
- private injector;
78
- private fileService;
79
- private keyService;
80
- private keyMeta;
81
- private keyFactory;
82
- private keyGraph;
83
- constructor(ngZone: NgZone, injector: Injector, fileService: FileService, keyService: KeyService, keyMeta: KeyMetaService, keyFactory: KeyFactoryService, keyGraph: KeyGraphService);
84
- downloadFileContent(options: DownloadFileContentOptions): Promise<ArrayBuffer>;
85
- createDirectory(options: CreateDirectoryOptions): Promise<LrMutation<CreateDirectoryMutation, {
86
- input: {
87
- parentDirectories: ParentDirectoryInput[];
88
- parentRootDirectory: ParentRootDirectoryInput;
89
- plainMeta: string;
90
- cipherMeta: string;
91
- };
92
- }>>;
93
- updateDirectoryExec(options: UpdateDirectoryOptions): Promise<UpdateDirectoryMutation>;
94
- updateDirectory(options: UpdateDirectoryOptions): Promise<LrMutation<UpdateDirectoryMutation, {
95
- input: {
96
- directoryId: string;
97
- plainMeta: string;
98
- cipherMeta: string;
99
- };
100
- }>>;
101
- updateDirectoryMutation(options: UpdateDirectoryOptions): Promise<LrMutation<UpdateDirectoryMutation, {
102
- input: {
103
- directoryId: string;
104
- plainMeta: string;
105
- cipherMeta: string;
106
- };
107
- }>>;
108
- deleteDirectory(id: ID): LrMutation<DeleteDirectoryMutation, {
109
- input: {
110
- directoryId: string;
111
- };
112
- }>;
113
- createFile(options: CreateFileOptions): Promise<LrMutation<CreateFileMutation, {
114
- input: {
115
- parentDirectories: FileParentDirectoryInput[];
116
- wrappedStateKey: string;
117
- contentResource: string;
118
- plainMeta: string;
119
- cipherMeta: string;
120
- };
121
- }>>;
122
- updateFile(options: UpdateFileOptions): Promise<LrMutation<UpdateFileMutation, {
123
- input: {
124
- fileId: string;
125
- wrappedStateKey: string;
126
- contentResource: string;
127
- plainMeta: string;
128
- cipherMeta: string;
129
- };
130
- }>>;
131
- deleteFile(id: ID): LrMutation<DeleteFileMutation, {
132
- input: {
133
- fileId: string;
134
- };
135
- }>;
136
- private getParentDirectoryInput;
137
- getFileStateKeyId(fileStateNodeId: LrRelayIdInput): Promise<string>;
138
- getDirectoryKeyId(directoryId: LrRelayIdInput): Promise<string>;
139
- getFileKeyId(fileId: LrRelayIdInput): Promise<string>;
140
- getDirectoryKey(directoryId: LrRelayIdInput, directoryKeyId?: LrRelayIdInput): Promise<import("../cryptography/cryptography.types").Key>;
141
- getFileKey(fileId: LrRelayIdInput, fileKeyId?: LrRelayIdInput): Promise<import("../cryptography/cryptography.types").Key>;
142
- private getInput;
143
- private createFileState;
144
- archiveDirectory(directoryId: string, recursive: boolean): LrMutation<ArchiveDirectoryMutation, {
145
- input: {
146
- directoryId: string;
147
- recursive: boolean;
148
- };
149
- }>;
150
- unarchiveDirectory(directoryId: string, recursive: boolean): LrMutation<UnarchiveDirectoryMutation, {
151
- input: {
152
- directoryId: string;
153
- recursive: boolean;
154
- };
155
- }>;
156
- protected getChangeItemParentsInput(options: ChangeItemParentsOptions, itemKey: JWK.Key): Promise<{
157
- directoriesToRemove: string[];
158
- directoriesToAdd: ParentDirectoryInput[];
159
- }>;
160
- changeDirectoryParents(options: ChangeDirectoryParentsOptions): Promise<import("./item2.gql").ChangeDirectoryParentsMutationResult>;
161
- changeDirectoryParentsMutation(options: ChangeDirectoryParentsOptions): Promise<LrMutation<import("./item2.gql").ChangeDirectoryParentsMutationResult, {
162
- input: {
163
- directoryId: string;
164
- directoriesToRemove: string[];
165
- directoriesToAdd: ParentDirectoryInput[];
166
- };
167
- }>>;
168
- changeFileParents(options: ChangeFileParentsOptions): Promise<import("./item2.gql").ChangeFileParentsMutationResult>;
169
- changeFileParentsMutation(options: ChangeFileParentsOptions): Promise<LrMutation<import("./item2.gql").ChangeFileParentsMutationResult, {
170
- input: {
171
- fileId: string;
172
- directoriesToRemove: string[];
173
- directoriesToAdd: ParentDirectoryInput[];
174
- };
175
- }>>;
176
- }
177
- export {};
@@ -1,7 +0,0 @@
1
- export declare const SubAssemblyFields: string;
2
- export declare const CreateScenarioApproverAssemblyMutation: import("graphql").DocumentNode;
3
- export declare const UpdateScenarioApproverAssemblyMutation: import("graphql").DocumentNode;
4
- export declare const DeleteScenarioApproverAssemblyMutation: import("graphql").DocumentNode;
5
- export declare const GetScenarioApproverQuery: import("graphql").DocumentNode;
6
- export declare const AddScenarioApproverMutation: import("graphql").DocumentNode;
7
- export declare const UpdateScenarioApproverMutation: import("graphql").DocumentNode;
@@ -1,63 +0,0 @@
1
- import { Receiver } from './../receivers/scenario-receiver.types';
2
- import { TrustedParty } from '../../trusted-parties/trusted-party.types';
3
- export interface ApprovalGroup {
4
- id: string;
5
- keyId: string;
6
- name: string;
7
- singleReject: boolean;
8
- quorum: number;
9
- approvers?: Approver[];
10
- }
11
- export interface Approver {
12
- id: string;
13
- keyId: string;
14
- trustedParty: TrustedParty;
15
- message?: string;
16
- }
17
- export interface ScenarioApproverAssemblyInput {
18
- scenarioId: string;
19
- keyId: string;
20
- singleReject: boolean;
21
- quorum: number;
22
- plainAssemblyCipherData?: any;
23
- }
24
- export interface CreateSubAssemblyInput {
25
- quorum: number;
26
- singleReject: boolean;
27
- plainSubAssemblyCipherData: any;
28
- }
29
- export interface CreateScenarioApprovalGroups {
30
- scenarioId: string;
31
- event: string;
32
- keyId: string;
33
- quorum: number;
34
- singleReject: boolean;
35
- plainAssemblyCipherData?: string;
36
- approvalGroups: UpdateScenarioApprovalGroup[];
37
- receivers?: Receiver[];
38
- }
39
- export interface UpdateScenarioApprovalGroups {
40
- scenarioId: string;
41
- assemblyKeyId: string;
42
- quorum: number;
43
- singleReject: boolean;
44
- plainAssemblyCipherData?: string;
45
- approvalGroups: UpdateScenarioApprovalGroup[];
46
- deletedGroupIds: string[];
47
- }
48
- export interface UpdateScenarioApprovalGroup {
49
- subAssemblyId?: string;
50
- quorum: number;
51
- singleReject: boolean;
52
- plainSubAssemblyCipherData: object;
53
- approvers: UpdateScenarioApprover[];
54
- deletedApproverIds?: string[];
55
- }
56
- export interface UpdateScenarioApprover {
57
- approverId?: string;
58
- keyId?: string;
59
- trustedPartyId: string;
60
- trustedPartySharedKeyId: string;
61
- plainSharedCipherData: object;
62
- approvalData?: string;
63
- }
@@ -1,32 +0,0 @@
1
- import { LrApolloService } from '../../api/lr-apollo.service';
2
- import { EncryptionService } from '../../cryptography/encryption.service';
3
- import { KeyFactoryService } from '../../cryptography/key-factory.service';
4
- import { KeyGraphService } from '../../cryptography/key-graph.service';
5
- import { KeyMetaService } from '../../cryptography/key-meta.service';
6
- import * as slip from '../../cryptography/slip39.service';
7
- import { TrustedPartyService } from '../../trusted-parties/trusted-party.service';
8
- import { Receiver } from '../receivers/scenario-receiver.types';
9
- import { ApprovalGroup, Approver, CreateScenarioApprovalGroups, UpdateScenarioApprovalGroups, UpdateScenarioApprover } from './scenario-approval.types';
10
- export declare class ScenarioApproverService {
11
- private lrApollo;
12
- private keyFactory;
13
- private keyMetaService;
14
- private keyGraph;
15
- private slip39Service;
16
- private encryptionService;
17
- private trustedPartyService;
18
- static SLIP39_PASSPHRASE: string;
19
- constructor(lrApollo: LrApolloService, keyFactory: KeyFactoryService, keyMetaService: KeyMetaService, keyGraph: KeyGraphService, slip39Service: slip.Slip39Service, encryptionService: EncryptionService, trustedPartyService: TrustedPartyService);
20
- getApprover(approverId: string): Promise<Approver>;
21
- mapApproverGroup(group: any): Promise<ApprovalGroup>;
22
- private mapApprover;
23
- updateApprover(approver: UpdateScenarioApprover): Promise<void>;
24
- createScenarioApproverAssembly(input: CreateScenarioApprovalGroups): Promise<string>;
25
- updateScenarioApproverAssembly(input: UpdateScenarioApprovalGroups): Promise<void>;
26
- deleteScenarioApproverAssembly(scenarioId: string, event: string, receivers: Receiver[]): Promise<void>;
27
- private rewrapReceivers;
28
- private mapApprovalGroups;
29
- private mapApprovalGroup;
30
- private mapApprovers;
31
- private createSlipAssembly;
32
- }
@@ -1,5 +0,0 @@
1
- export declare const ClaimantFields: string;
2
- export declare const GetScenarioClaimantQuery: import("graphql").DocumentNode;
3
- export declare const AddScenarioClaimantMutation: import("graphql").DocumentNode;
4
- export declare const UpdateScenarioClaimantMutation: import("graphql").DocumentNode;
5
- export declare const DeleteScenarioClaimantMutation: import("graphql").DocumentNode;
@@ -1,17 +0,0 @@
1
- import { LrApolloService } from '../../api/lr-apollo.service';
2
- import { KeyGraphService } from '../../cryptography/key-graph.service';
3
- import { KeyMetaService } from '../../cryptography/key-meta.service';
4
- import { TrustedPartyService } from '../../trusted-parties/trusted-party.service';
5
- import { Claimant, AddScenarioClaimant, UpdateScenarioClaimant } from './scenario-claimant.types';
6
- export declare class ScenarioClaimantService {
7
- private lrApollo;
8
- private keyMetaService;
9
- private keyGraph;
10
- private tpService;
11
- constructor(lrApollo: LrApolloService, keyMetaService: KeyMetaService, keyGraph: KeyGraphService, tpService: TrustedPartyService);
12
- getClaimant(claimantId: string): Promise<Claimant>;
13
- mapClaimant(claimant: any): Promise<Claimant>;
14
- addClaimant(claimant: AddScenarioClaimant): Promise<string>;
15
- updateClaimant(claimant: UpdateScenarioClaimant): Promise<string>;
16
- deleteClaimant(claimantId: string): Promise<void>;
17
- }
@@ -1,18 +0,0 @@
1
- import { TrustedParty } from '../../trusted-parties/trusted-party.types';
2
- export interface Claimant {
3
- id: string;
4
- keyId: string;
5
- trustedParty: TrustedParty;
6
- message?: string;
7
- }
8
- export interface AddScenarioClaimant {
9
- scenarioId: string;
10
- trustedPartyId: string;
11
- trustedPartySharedKeyId: string;
12
- plainSharedCipherData: object;
13
- }
14
- export interface UpdateScenarioClaimant {
15
- id: string;
16
- keyId: string;
17
- plainSharedCipherData: object;
18
- }