@lifeready/core 1.0.3 → 1.0.5

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 (225) hide show
  1. package/README.md +62 -62
  2. package/bundles/lifeready-core.umd.js +15445 -15445
  3. package/bundles/lifeready-core.umd.js.map +1 -1
  4. package/bundles/lifeready-core.umd.min.js.map +1 -1
  5. package/esm2015/lib/_common/ast.js +40 -40
  6. package/esm2015/lib/_common/deferred-promise.js +24 -24
  7. package/esm2015/lib/_common/exceptions.js +157 -157
  8. package/esm2015/lib/_common/queries.gql.js +190 -190
  9. package/esm2015/lib/_common/run-outside-angular.js +79 -79
  10. package/esm2015/lib/_common/types.js +1 -1
  11. package/esm2015/lib/_common/utils.js +44 -44
  12. package/esm2015/lib/api/contact-card.gql.js +79 -79
  13. package/esm2015/lib/api/contact-card.service.js +154 -154
  14. package/esm2015/lib/api/contact-card2.gql.js +60 -60
  15. package/esm2015/lib/api/contact-card2.service.js +103 -103
  16. package/esm2015/lib/api/file.service.js +74 -74
  17. package/esm2015/lib/api/item2.gql.js +110 -110
  18. package/esm2015/lib/api/item2.service.js +311 -311
  19. package/esm2015/lib/api/key-exchange.gql.js +188 -188
  20. package/esm2015/lib/api/key-exchange.service.js +442 -442
  21. package/esm2015/lib/api/key-exchange.types.js +18 -18
  22. package/esm2015/lib/api/key-exchange2.gql.js +171 -171
  23. package/esm2015/lib/api/key-exchange2.service.js +479 -479
  24. package/esm2015/lib/api/lock.gql.js +40 -40
  25. package/esm2015/lib/api/lock.service.js +64 -64
  26. package/esm2015/lib/api/lr-apollo.service.js +46 -46
  27. package/esm2015/lib/api/lr-graphql/index.js +6 -6
  28. package/esm2015/lib/api/lr-graphql/lr-graphql.service.js +155 -155
  29. package/esm2015/lib/api/lr-graphql/lr-merged-mutation.js +213 -213
  30. package/esm2015/lib/api/lr-graphql/lr-mutation-base.js +51 -51
  31. package/esm2015/lib/api/lr-graphql/lr-mutation.js +48 -48
  32. package/esm2015/lib/api/lr-graphql/lr.service.js +18 -18
  33. package/esm2015/lib/api/message.service.js +138 -138
  34. package/esm2015/lib/api/persist.service.js +181 -181
  35. package/esm2015/lib/api/query-processor/common-processors.service.js +93 -93
  36. package/esm2015/lib/api/query-processor/index.js +3 -3
  37. package/esm2015/lib/api/query-processor/query-processor.service.js +192 -192
  38. package/esm2015/lib/api/query-processor/tp-password-reset-processor.service.js +109 -109
  39. package/esm2015/lib/api/shared-contact-card.service.js +119 -119
  40. package/esm2015/lib/api/shared-contact-card2.gql.js +41 -41
  41. package/esm2015/lib/api/shared-contact-card2.service.js +117 -117
  42. package/esm2015/lib/api/time.service.js +146 -146
  43. package/esm2015/lib/api/types/graphql.types.js +7 -7
  44. package/esm2015/lib/api/types/index.js +3 -3
  45. package/esm2015/lib/api/types/lr-graphql.types.js +71 -71
  46. package/esm2015/lib/auth/auth.config.js +57 -57
  47. package/esm2015/lib/auth/auth.gql.js +48 -48
  48. package/esm2015/lib/auth/auth.types.js +27 -27
  49. package/esm2015/lib/auth/idle.service.js +168 -168
  50. package/esm2015/lib/auth/idle.types.js +7 -7
  51. package/esm2015/lib/auth/lbop.service.js +355 -355
  52. package/esm2015/lib/auth/life-ready-auth.service.js +500 -500
  53. package/esm2015/lib/auth/password.service.js +320 -320
  54. package/esm2015/lib/auth/register.service.js +172 -172
  55. package/esm2015/lib/auth/two-factor.service.js +74 -74
  56. package/esm2015/lib/category/category-meta.service.js +99 -99
  57. package/esm2015/lib/category/category.gql.js +406 -406
  58. package/esm2015/lib/category/category.service.js +390 -390
  59. package/esm2015/lib/category/category.types.js +29 -29
  60. package/esm2015/lib/cryptography/cryptography.types.js +11 -11
  61. package/esm2015/lib/cryptography/encryption.service.js +189 -189
  62. package/esm2015/lib/cryptography/key-factory.service.js +237 -237
  63. package/esm2015/lib/cryptography/key-graph.service.js +280 -280
  64. package/esm2015/lib/cryptography/key-meta.service.js +200 -200
  65. package/esm2015/lib/cryptography/key.service.js +124 -124
  66. package/esm2015/lib/cryptography/slip39.service.js +169 -169
  67. package/esm2015/lib/cryptography/web-crypto.service.js +29 -29
  68. package/esm2015/lib/life-ready.config.js +84 -84
  69. package/esm2015/lib/life-ready.module.js +74 -74
  70. package/esm2015/lib/plan/plan.gql.js +123 -123
  71. package/esm2015/lib/plan/plan.service.js +149 -149
  72. package/esm2015/lib/plan/plan.types.js +11 -11
  73. package/esm2015/lib/record/record-attachment.service.js +101 -101
  74. package/esm2015/lib/record/record.gql.js +179 -179
  75. package/esm2015/lib/record/record.service.js +206 -206
  76. package/esm2015/lib/record/record.types.js +15 -15
  77. package/esm2015/lib/record-type/record-type.service.js +75 -75
  78. package/esm2015/lib/record-type/record-type.types.js +28 -28
  79. package/esm2015/lib/scenario/approvals/scenario-approval.gql.js +105 -105
  80. package/esm2015/lib/scenario/approvals/scenario-approval.types.js +1 -1
  81. package/esm2015/lib/scenario/approvals/scenario-approver.service.js +300 -300
  82. package/esm2015/lib/scenario/claimants/scenario-claimant.gql.js +52 -52
  83. package/esm2015/lib/scenario/claimants/scenario-claimant.service.js +97 -97
  84. package/esm2015/lib/scenario/claimants/scenario-claimant.types.js +1 -1
  85. package/esm2015/lib/scenario/receivers/scenario-receiver.gql.js +150 -150
  86. package/esm2015/lib/scenario/receivers/scenario-receiver.service.js +229 -229
  87. package/esm2015/lib/scenario/receivers/scenario-receiver.types.js +1 -1
  88. package/esm2015/lib/scenario/scenario-setup.service.js +269 -269
  89. package/esm2015/lib/scenario/scenario.gql.js +368 -368
  90. package/esm2015/lib/scenario/scenario.service.js +611 -611
  91. package/esm2015/lib/scenario/scenario.types.js +64 -64
  92. package/esm2015/lib/search/search.gql.js +62 -62
  93. package/esm2015/lib/search/search.service.js +156 -156
  94. package/esm2015/lib/search/search.types.js +6 -6
  95. package/esm2015/lib/trusted-parties/tp-password-reset-request.service.js +112 -112
  96. package/esm2015/lib/trusted-parties/tp-password-reset-user.service.js +129 -129
  97. package/esm2015/lib/trusted-parties/tp-password-reset.constants.js +4 -4
  98. package/esm2015/lib/trusted-parties/tp-password-reset.gql.js +232 -232
  99. package/esm2015/lib/trusted-parties/tp-password-reset.service.js +299 -299
  100. package/esm2015/lib/trusted-parties/trusted-party.gql.js +148 -148
  101. package/esm2015/lib/trusted-parties/trusted-party.service.js +326 -326
  102. package/esm2015/lib/trusted-parties/trusted-party.types.js +41 -41
  103. package/esm2015/lib/trusted-parties/trusted-party2.gql.js +87 -87
  104. package/esm2015/lib/trusted-parties/trusted-party2.service.js +215 -215
  105. package/esm2015/lib/users/profile-details.service.js +214 -214
  106. package/esm2015/lib/users/profile.gql.js +97 -97
  107. package/esm2015/lib/users/profile.service.js +169 -169
  108. package/esm2015/lib/users/profile.types.js +34 -34
  109. package/esm2015/lib/users/user.gql.js +60 -60
  110. package/esm2015/lib/users/user.service.js +79 -79
  111. package/esm2015/lib/users/user.types.js +5 -5
  112. package/esm2015/lifeready-core.js +10 -10
  113. package/esm2015/public-api.js +81 -81
  114. package/fesm2015/lifeready-core.js +13088 -13088
  115. package/fesm2015/lifeready-core.js.map +1 -1
  116. package/lib/_common/ast.d.ts +11 -11
  117. package/lib/_common/deferred-promise.d.ts +12 -12
  118. package/lib/_common/exceptions.d.ts +109 -109
  119. package/lib/_common/queries.gql.d.ts +10 -10
  120. package/lib/_common/run-outside-angular.d.ts +14 -14
  121. package/lib/_common/types.d.ts +10 -10
  122. package/lib/_common/utils.d.ts +3 -3
  123. package/lib/api/contact-card.gql.d.ts +7 -7
  124. package/lib/api/contact-card.service.d.ts +52 -52
  125. package/lib/api/contact-card2.gql.d.ts +34 -34
  126. package/lib/api/contact-card2.service.d.ts +49 -49
  127. package/lib/api/file.service.d.ts +18 -18
  128. package/lib/api/item2.gql.d.ts +96 -96
  129. package/lib/api/item2.service.d.ts +177 -177
  130. package/lib/api/key-exchange.gql.d.ts +9 -9
  131. package/lib/api/key-exchange.service.d.ts +39 -39
  132. package/lib/api/key-exchange.types.d.ts +196 -196
  133. package/lib/api/key-exchange2.gql.d.ts +125 -125
  134. package/lib/api/key-exchange2.service.d.ts +187 -187
  135. package/lib/api/lock.gql.d.ts +27 -27
  136. package/lib/api/lock.service.d.ts +25 -25
  137. package/lib/api/lr-apollo.service.d.ts +15 -15
  138. package/lib/api/lr-graphql/index.d.ts +5 -5
  139. package/lib/api/lr-graphql/lr-graphql.service.d.ts +60 -60
  140. package/lib/api/lr-graphql/lr-merged-mutation.d.ts +27 -27
  141. package/lib/api/lr-graphql/lr-mutation-base.d.ts +28 -28
  142. package/lib/api/lr-graphql/lr-mutation.d.ts +8 -8
  143. package/lib/api/lr-graphql/lr.service.d.ts +9 -9
  144. package/lib/api/message.service.d.ts +58 -58
  145. package/lib/api/persist.service.d.ts +31 -31
  146. package/lib/api/query-processor/common-processors.service.d.ts +36 -36
  147. package/lib/api/query-processor/index.d.ts +2 -2
  148. package/lib/api/query-processor/query-processor.service.d.ts +18 -18
  149. package/lib/api/query-processor/tp-password-reset-processor.service.d.ts +15 -15
  150. package/lib/api/shared-contact-card.service.d.ts +33 -33
  151. package/lib/api/shared-contact-card2.gql.d.ts +36 -36
  152. package/lib/api/shared-contact-card2.service.d.ts +45 -45
  153. package/lib/api/time.service.d.ts +16 -16
  154. package/lib/api/types/graphql.types.d.ts +29 -29
  155. package/lib/api/types/index.d.ts +2 -2
  156. package/lib/api/types/lr-graphql.types.d.ts +385 -385
  157. package/lib/auth/auth.config.d.ts +5 -5
  158. package/lib/auth/auth.gql.d.ts +15 -15
  159. package/lib/auth/auth.types.d.ts +66 -66
  160. package/lib/auth/idle.service.d.ts +40 -40
  161. package/lib/auth/idle.types.d.ts +10 -10
  162. package/lib/auth/lbop.service.d.ts +91 -91
  163. package/lib/auth/life-ready-auth.service.d.ts +59 -59
  164. package/lib/auth/password.service.d.ts +78 -78
  165. package/lib/auth/register.service.d.ts +25 -25
  166. package/lib/auth/two-factor.service.d.ts +15 -15
  167. package/lib/category/category-meta.service.d.ts +23 -23
  168. package/lib/category/category.gql.d.ts +45 -45
  169. package/lib/category/category.service.d.ts +67 -67
  170. package/lib/category/category.types.d.ts +79 -79
  171. package/lib/cryptography/cryptography.types.d.ts +83 -83
  172. package/lib/cryptography/encryption.service.d.ts +41 -41
  173. package/lib/cryptography/key-factory.service.d.ts +38 -38
  174. package/lib/cryptography/key-graph.service.d.ts +33 -33
  175. package/lib/cryptography/key-meta.service.d.ts +44 -44
  176. package/lib/cryptography/key.service.d.ts +36 -36
  177. package/lib/cryptography/slip39.service.d.ts +43 -43
  178. package/lib/cryptography/web-crypto.service.d.ts +5 -5
  179. package/lib/life-ready.config.d.ts +14 -14
  180. package/lib/life-ready.module.d.ts +5 -5
  181. package/lib/plan/plan.gql.d.ts +11 -11
  182. package/lib/plan/plan.service.d.ts +33 -33
  183. package/lib/plan/plan.types.d.ts +31 -31
  184. package/lib/record/record-attachment.service.d.ts +16 -16
  185. package/lib/record/record.gql.d.ts +14 -14
  186. package/lib/record/record.service.d.ts +25 -25
  187. package/lib/record/record.types.d.ts +57 -57
  188. package/lib/record-type/record-type.service.d.ts +11 -11
  189. package/lib/record-type/record-type.types.d.ts +50 -50
  190. package/lib/scenario/approvals/scenario-approval.gql.d.ts +7 -7
  191. package/lib/scenario/approvals/scenario-approval.types.d.ts +63 -63
  192. package/lib/scenario/approvals/scenario-approver.service.d.ts +32 -32
  193. package/lib/scenario/claimants/scenario-claimant.gql.d.ts +5 -5
  194. package/lib/scenario/claimants/scenario-claimant.service.d.ts +17 -17
  195. package/lib/scenario/claimants/scenario-claimant.types.d.ts +18 -18
  196. package/lib/scenario/receivers/scenario-receiver.gql.d.ts +8 -8
  197. package/lib/scenario/receivers/scenario-receiver.service.d.ts +30 -30
  198. package/lib/scenario/receivers/scenario-receiver.types.d.ts +54 -54
  199. package/lib/scenario/scenario-setup.service.d.ts +22 -22
  200. package/lib/scenario/scenario.gql.d.ts +34 -34
  201. package/lib/scenario/scenario.service.d.ts +58 -58
  202. package/lib/scenario/scenario.types.d.ts +217 -217
  203. package/lib/search/search.gql.d.ts +1 -1
  204. package/lib/search/search.service.d.ts +25 -25
  205. package/lib/search/search.types.d.ts +20 -20
  206. package/lib/trusted-parties/tp-password-reset-request.service.d.ts +20 -20
  207. package/lib/trusted-parties/tp-password-reset-user.service.d.ts +35 -35
  208. package/lib/trusted-parties/tp-password-reset.constants.d.ts +3 -3
  209. package/lib/trusted-parties/tp-password-reset.gql.d.ts +218 -218
  210. package/lib/trusted-parties/tp-password-reset.service.d.ts +130 -130
  211. package/lib/trusted-parties/trusted-party.gql.d.ts +9 -9
  212. package/lib/trusted-parties/trusted-party.service.d.ts +44 -44
  213. package/lib/trusted-parties/trusted-party.types.d.ts +102 -102
  214. package/lib/trusted-parties/trusted-party2.gql.d.ts +79 -79
  215. package/lib/trusted-parties/trusted-party2.service.d.ts +114 -114
  216. package/lib/users/profile-details.service.d.ts +21 -21
  217. package/lib/users/profile.gql.d.ts +11 -11
  218. package/lib/users/profile.service.d.ts +35 -35
  219. package/lib/users/profile.types.d.ts +96 -96
  220. package/lib/users/user.gql.d.ts +9 -9
  221. package/lib/users/user.service.d.ts +12 -12
  222. package/lib/users/user.types.d.ts +23 -23
  223. package/lifeready-core.d.ts +9 -9
  224. package/package.json +1 -1
  225. package/public-api.d.ts +77 -77
@@ -1,611 +1,611 @@
1
- import { __awaiter, __rest } from "tslib";
2
- import { Injectable } from '@angular/core';
3
- import { LrApolloService } from '../api/lr-apollo.service';
4
- import { CategoryFilter, RecordFilter } from '../category/category.gql';
5
- import { EncryptionService } from '../cryptography/encryption.service';
6
- import { KeyGraphService } from '../cryptography/key-graph.service';
7
- import { KeyMetaService } from '../cryptography/key-meta.service';
8
- import { KeyService } from '../cryptography/key.service';
9
- import * as slip from '../cryptography/slip39.service';
10
- import { RecordContentFilter } from '../record/record.gql';
11
- import { TrustedPartyService } from '../trusted-parties/trusted-party.service';
12
- import { LrException, LrErrorCode, } from '../_common/exceptions';
13
- import { ScenarioApproverService } from './approvals/scenario-approver.service';
14
- import { ScenarioClaimantService } from './claimants/scenario-claimant.service';
15
- import { ScenarioReceiverService } from './receivers/scenario-receiver.service';
16
- import { ApproveScenarioClaimMutation, CancelScenarioClaimMutation, CreateScenarioClaimMutation, CreateScenarioMutation, DeleteScenarioMutation, DisableScenarioMutation, EnableScenarioMutation, GetAllScenarioClaimsQuery, GetAllScenariosQuery, GetAllSharedScenariosQuery, GetScenarioQuery, GetSharedScenarioQuery, GetTrustedPartyScenariosQuery, ReceiveScenarioClaimMutation, RejectScenarioClaimMutation, ResetScenarioMutation, UpdateScenarioMutation, GetAllScenarioIdsQuery, } from './scenario.gql';
17
- import { ScenarioState, ApproverClaimState, } from './scenario.types';
18
- import * as moment_ from 'moment';
19
- import { KeyFactoryService as KFS } from '../cryptography/key-factory.service';
20
- import { LrGraphQLService, LrMergedMutation, LrMutation, } from '../api/lr-graphql';
21
- import * as i0 from "@angular/core";
22
- import * as i1 from "../api/lr-apollo.service";
23
- import * as i2 from "../cryptography/key-meta.service";
24
- import * as i3 from "../cryptography/key-factory.service";
25
- import * as i4 from "../cryptography/key.service";
26
- import * as i5 from "../cryptography/encryption.service";
27
- import * as i6 from "../cryptography/key-graph.service";
28
- import * as i7 from "../trusted-parties/trusted-party.service";
29
- import * as i8 from "../cryptography/slip39.service";
30
- import * as i9 from "./claimants/scenario-claimant.service";
31
- import * as i10 from "./approvals/scenario-approver.service";
32
- import * as i11 from "./receivers/scenario-receiver.service";
33
- import * as i12 from "../api/lr-graphql/lr-graphql.service";
34
- // Ref: https://stackoverflow.com/questions/59735280/angular-8-moment-error-cannot-call-a-namespace-moment
35
- const moment = moment_;
36
- export class ScenarioService {
37
- constructor(lrApollo, keyMetaService, keyFactory, keyService, encryptionService, keyGraph, tpService, slip39Service, scenarioClaimantService, scenarioApproverService, scenarioReceiverService, lrGraphQL) {
38
- this.lrApollo = lrApollo;
39
- this.keyMetaService = keyMetaService;
40
- this.keyFactory = keyFactory;
41
- this.keyService = keyService;
42
- this.encryptionService = encryptionService;
43
- this.keyGraph = keyGraph;
44
- this.tpService = tpService;
45
- this.slip39Service = slip39Service;
46
- this.scenarioClaimantService = scenarioClaimantService;
47
- this.scenarioApproverService = scenarioApproverService;
48
- this.scenarioReceiverService = scenarioReceiverService;
49
- this.lrGraphQL = lrGraphQL;
50
- }
51
- getMyScenarios() {
52
- return __awaiter(this, void 0, void 0, function* () {
53
- const { scenarios } = yield this.lrApollo.query({
54
- query: GetAllScenariosQuery,
55
- });
56
- return yield Promise.all(scenarios.edges.map((x) => this.mapScenarioSummary(x.node)));
57
- });
58
- }
59
- mapScenarioSummary(scenario) {
60
- return __awaiter(this, void 0, void 0, function* () {
61
- const { event, name } = yield this.keyGraph.decryptFromString(scenario.subjectKey.id, scenario.subjectCipherData);
62
- return {
63
- id: scenario.id,
64
- name,
65
- event,
66
- status: scenario.state,
67
- claimId: scenario.claim && scenario.claim.id,
68
- claimStatus: scenario.claim && scenario.claim.state,
69
- createdOn: scenario.created,
70
- lastModified: scenario.modified,
71
- };
72
- });
73
- }
74
- getSharedScenarios() {
75
- return __awaiter(this, void 0, void 0, function* () {
76
- const { sharedScenarios } = yield this.lrApollo.query({
77
- query: GetAllSharedScenariosQuery,
78
- });
79
- return (yield Promise.all(sharedScenarios.edges.map((x) => this.mapSharedScenario(x.node)))).filter((x) => x);
80
- });
81
- }
82
- mapSharedScenarioSummary(scenario) {
83
- return __awaiter(this, void 0, void 0, function* () {
84
- const { event, name } = yield this.keyGraph.decryptFromString(scenario.subjectKey.id, scenario.subjectCipherData);
85
- return {
86
- id: scenario.id,
87
- name,
88
- event,
89
- status: scenario.state,
90
- claimId: scenario.claim && scenario.claim.id,
91
- claimStatus: scenario.claim && scenario.claim.state,
92
- createdOn: scenario.created,
93
- lastModified: scenario.modified,
94
- };
95
- });
96
- }
97
- getSharedScenario(scenarioId) {
98
- return __awaiter(this, void 0, void 0, function* () {
99
- const { sharedScenario } = yield this.lrApollo.query({
100
- query: GetSharedScenarioQuery,
101
- variables: {
102
- id: scenarioId,
103
- },
104
- });
105
- return yield this.mapSharedScenario(sharedScenario);
106
- });
107
- }
108
- mapSharedScenario(scenario) {
109
- return __awaiter(this, void 0, void 0, function* () {
110
- try {
111
- const claimantData = yield this.getCipherData(scenario.asClaimant);
112
- const receiverData = yield this.getCipherData(scenario.asReceiver);
113
- const approverData = yield Promise.all(scenario.asApprovers.edges.map((x) => this.getCipherData(x.node.approver)));
114
- return {
115
- id: scenario.id,
116
- event: claimantData.event ||
117
- receiverData.event ||
118
- approverData.map((x) => x.event)[0],
119
- status: scenario.state,
120
- trustedParty: yield this.tpService.mapTrustedParty(scenario.tp),
121
- isClaimant: !!scenario.asClaimant,
122
- claimantMessage: claimantData.message,
123
- isApprover: scenario.asApprovers.edges.length > 0,
124
- approverMessages: approverData.map((x) => x.message),
125
- isReceiver: !!scenario.asReceiver,
126
- receiverMessage: receiverData.message,
127
- receiverKeyId: scenario.asReceiver && scenario.asReceiver.sharedKey.id,
128
- receiverPbkId: scenario.asReceiver && scenario.asReceiver.pbk.id,
129
- receiverDirectories: scenario.asReceiver &&
130
- scenario.asReceiver.receiverDirectories.edges.map((x) => x.node),
131
- claim: scenario.sharedClaim
132
- ? {
133
- id: scenario.sharedClaim.id,
134
- isClaimant: scenario.sharedClaim.isClaimant,
135
- status: scenario.sharedClaim.state,
136
- asApprovers: yield Promise.all(scenario.sharedClaim.asClaimApprovers.edges
137
- .map((x) => x.node)
138
- .map((x) => __awaiter(this, void 0, void 0, function* () {
139
- return ({
140
- approverId: x.approver.id,
141
- approverKey: yield this.getApproverKey(x.approver),
142
- status: x.state,
143
- receivers: x.receivers.edges.map((y) => ({
144
- id: y.node.id,
145
- pbkId: y.node.pbk.id,
146
- })),
147
- });
148
- }))),
149
- asReceiver: scenario.sharedClaim.asClaimReceiver
150
- ? {
151
- received: scenario.sharedClaim.asClaimReceiver.received,
152
- ciphers: scenario.sharedClaim.asClaimReceiver.approvals.edges.map((x) => x.node.receiverPbkCipher),
153
- }
154
- : null,
155
- }
156
- : null,
157
- };
158
- }
159
- catch (e) {
160
- console.error('Failed to decrypt shared scenario.', e, scenario);
161
- return null;
162
- }
163
- });
164
- }
165
- getTrustedPartyScenarios(trustedPartyId) {
166
- return __awaiter(this, void 0, void 0, function* () {
167
- const { tp } = yield this.lrApollo.query({
168
- query: GetTrustedPartyScenariosQuery,
169
- variables: { partyId: trustedPartyId },
170
- });
171
- return {
172
- myScenarios: yield Promise.all(tp.myScenarios.edges.map((x) => this.mapScenarioSummary(x.node))),
173
- sharedScenarios: yield Promise.all(tp.sharedScenarios.edges.map((x) => this.mapSharedScenario(x.node))),
174
- };
175
- });
176
- }
177
- getScenarioClaims() {
178
- return __awaiter(this, void 0, void 0, function* () {
179
- const { scenarios } = yield this.lrApollo.query({
180
- query: GetAllScenarioClaimsQuery,
181
- });
182
- const claims = yield Promise.all(scenarios.edges.map((x) => __awaiter(this, void 0, void 0, function* () {
183
- const scenario = yield this.mapScenarioSummary(x.node);
184
- return yield Promise.all(x.node.claims.edges.map((y) => __awaiter(this, void 0, void 0, function* () {
185
- return ({
186
- id: y.node.id,
187
- state: y.node.state,
188
- triggeredBy: yield this.tpService.mapTrustedParty(y.node.claimant.tp),
189
- triggeredOn: y.node.created,
190
- lastModified: y.node.modified,
191
- scenario,
192
- });
193
- })));
194
- })));
195
- return claims
196
- .reduce((x, y) => [...x, ...y], [])
197
- .sort((x, y) => -1 *
198
- moment(new Date(x.lastModified)).diff(moment(new Date(y.lastModified))));
199
- });
200
- }
201
- getCipherData(cipher) {
202
- return __awaiter(this, void 0, void 0, function* () {
203
- if (!cipher)
204
- return {};
205
- return yield this.keyGraph.decryptFromString(cipher.sharedKey.id, cipher.sharedCipherData);
206
- });
207
- }
208
- getApproverKey(cipher) {
209
- return __awaiter(this, void 0, void 0, function* () {
210
- if (!cipher)
211
- return null;
212
- return yield this.keyGraph.decryptFromString(cipher.sharedKey.id, cipher.sharedCipherPartialAssemblyKey);
213
- });
214
- }
215
- getScenario(scenarioId) {
216
- return __awaiter(this, void 0, void 0, function* () {
217
- const { scenario } = yield this.lrApollo.query({
218
- query: GetScenarioQuery,
219
- variables: {
220
- id: scenarioId,
221
- categoryFilter: CategoryFilter,
222
- recordFilter: RecordFilter,
223
- contentFilter: RecordContentFilter,
224
- },
225
- });
226
- return yield this.mapScenario(scenario);
227
- });
228
- }
229
- mapScenario(scenario) {
230
- return __awaiter(this, void 0, void 0, function* () {
231
- const { name, event } = yield this.keyGraph.decryptFromString(scenario.subjectKey.id, scenario.subjectCipherData);
232
- const claimants = yield Promise.all(scenario.claimants.edges.map((x) => this.scenarioClaimantService.mapClaimant(x.node)));
233
- return {
234
- id: scenario.id,
235
- keyId: scenario.subjectKey.id,
236
- assemblyKeyId: scenario.approverAssembly && scenario.approverAssembly.assemblyKey.id,
237
- assemblyQuorum: scenario.approverAssembly && scenario.approverAssembly.quorum,
238
- name,
239
- event,
240
- status: scenario.state,
241
- claimants,
242
- approverGroups: scenario.approverAssembly
243
- ? yield Promise.all(scenario.approverAssembly.subAssemblies.edges.map((x) => this.scenarioApproverService.mapApproverGroup(x.node)))
244
- : [],
245
- receivers: yield Promise.all(scenario.receivers.edges.map((x) => this.scenarioReceiverService.mapReceiver(x.node))),
246
- claim: scenario.claim
247
- ? {
248
- id: scenario.claim.id,
249
- status: scenario.claim.state,
250
- claimant: claimants.find((x) => x.id === scenario.claim.claimant.id),
251
- }
252
- : null,
253
- };
254
- });
255
- }
256
- createScenario(input) {
257
- return __awaiter(this, void 0, void 0, function* () {
258
- const rootKey = yield this.keyService.getCurrentRootKey();
259
- const subjectKey = yield this.keyFactory.createKey();
260
- const rootKeyWrappedSubjectKey = yield this.keyGraph.encryptToString(rootKey.jwk, subjectKey.toJSON(true));
261
- const subjectCipherData = yield this.keyGraph.encryptToString(subjectKey, input.plainSubjectCipherData);
262
- const { createScenario } = yield this.lrApollo.mutate({
263
- mutation: CreateScenarioMutation,
264
- variables: {
265
- input: {
266
- rootKeyId: rootKey.id,
267
- rootKeyWrappedSubjectKey,
268
- subjectCipherData,
269
- },
270
- },
271
- });
272
- return createScenario.scenario.id;
273
- });
274
- }
275
- updateScenario(input) {
276
- return __awaiter(this, void 0, void 0, function* () {
277
- yield this.lrApollo.mutate({
278
- mutation: UpdateScenarioMutation,
279
- variables: {
280
- input: {
281
- scenarioId: input.scenarioId,
282
- subjectKeyId: input.keyId,
283
- subjectCipherData: yield this.keyGraph.encryptToString(input.keyId, input.plainSubjectCipherData),
284
- },
285
- },
286
- });
287
- });
288
- }
289
- enableScenario(scenarioId) {
290
- return __awaiter(this, void 0, void 0, function* () {
291
- yield this.lrApollo.mutate({
292
- mutation: EnableScenarioMutation,
293
- variables: { input: { scenarioId } },
294
- });
295
- });
296
- }
297
- disableScenario(scenarioId) {
298
- return __awaiter(this, void 0, void 0, function* () {
299
- yield this.lrApollo.mutate({
300
- mutation: DisableScenarioMutation,
301
- variables: { input: { scenarioId } },
302
- });
303
- });
304
- }
305
- deleteScenario(scenarioId) {
306
- return __awaiter(this, void 0, void 0, function* () {
307
- yield this.lrApollo.mutate({
308
- mutation: DeleteScenarioMutation,
309
- variables: { input: { scenarioId } },
310
- });
311
- });
312
- }
313
- createClaim(scenarioId) {
314
- return __awaiter(this, void 0, void 0, function* () {
315
- const res = yield this.lrApollo.mutate({
316
- mutation: CreateScenarioClaimMutation,
317
- variables: { input: { scenarioId } },
318
- });
319
- return res.createScenarioClaim.sharedClaim.id;
320
- });
321
- }
322
- cancelClaim(claimId) {
323
- return __awaiter(this, void 0, void 0, function* () {
324
- yield this.lrApollo.mutate({
325
- mutation: CancelScenarioClaimMutation,
326
- variables: { input: { claimId } },
327
- });
328
- });
329
- }
330
- approveClaim(scenarioId, claimId) {
331
- return __awaiter(this, void 0, void 0, function* () {
332
- return this.lrGraphQL.lrMutate(this.approveClaimMutation(scenarioId, claimId));
333
- });
334
- }
335
- approveClaimMutation(scenarioId, claimId) {
336
- return __awaiter(this, void 0, void 0, function* () {
337
- const sharedScenario = yield this.getSharedScenario(scenarioId);
338
- // Double check the claim matches
339
- if (sharedScenario.claim.id !== claimId) {
340
- throw new LrException({
341
- code: LrErrorCode.ReceiveClaimMismatch,
342
- message: 'claimId does not match with the current claimId of the scenario',
343
- });
344
- }
345
- const createMutation = (asApprover) => __awaiter(this, void 0, void 0, function* () {
346
- return new LrMutation({
347
- mutation: ApproveScenarioClaimMutation,
348
- variables: {
349
- input: {
350
- claimId,
351
- approverId: asApprover.approverId,
352
- receivers: yield Promise.all(asApprover.receivers.map((y) => __awaiter(this, void 0, void 0, function* () {
353
- return ({
354
- receiverId: y.id,
355
- receiverPbkCipher: yield this.keyGraph.encryptToString(y.pbkId, { partialAssemblyKey: asApprover.approverKey }),
356
- });
357
- }))),
358
- },
359
- },
360
- });
361
- });
362
- const mutations = sharedScenario.claim.asApprovers
363
- .filter((asApprover) => asApprover.status === ApproverClaimState.Claimed)
364
- .map((asApprover) => createMutation(asApprover));
365
- return LrMergedMutation.create(yield Promise.all(mutations));
366
- });
367
- }
368
- rejectClaim(scenarioId, claimId) {
369
- return __awaiter(this, void 0, void 0, function* () {
370
- return this.lrGraphQL.lrMutate(this.rejectClaimMutation(scenarioId, claimId));
371
- });
372
- }
373
- rejectClaimMutation(scenarioId, claimId) {
374
- return __awaiter(this, void 0, void 0, function* () {
375
- const sharedScenario = yield this.getSharedScenario(scenarioId);
376
- // Double check the claim matches
377
- if (sharedScenario.claim.id !== claimId) {
378
- throw new LrException({
379
- code: LrErrorCode.ReceiveClaimMismatch,
380
- message: 'ClaimId does not match with the current claimId of the scenario',
381
- });
382
- }
383
- const createMutation = (asApprover) => __awaiter(this, void 0, void 0, function* () {
384
- return new LrMutation({
385
- mutation: RejectScenarioClaimMutation,
386
- variables: { input: { claimId, approverId: asApprover.approverId } },
387
- });
388
- });
389
- const mutations = sharedScenario.claim.asApprovers
390
- .filter((asApprover) => asApprover.status === ApproverClaimState.Claimed)
391
- .map((asApprover) => createMutation(asApprover));
392
- return LrMergedMutation.create(yield Promise.all(mutations));
393
- });
394
- }
395
- receiveClaim(scenarioId, claimId) {
396
- return __awaiter(this, void 0, void 0, function* () {
397
- // Get all the shared items
398
- const sharedScenario = yield this.getSharedScenario(scenarioId);
399
- // Double check the claim matches
400
- if (sharedScenario.claim.id !== claimId) {
401
- throw new LrException({
402
- code: LrErrorCode.ReceiveClaimMismatch,
403
- message: 'ClaimId does not match with the current claimId of the scenario',
404
- });
405
- }
406
- if (sharedScenario.status !== ScenarioState.APPROVED) {
407
- throw new LrException({
408
- code: LrErrorCode.BadState,
409
- message: 'Scenario claim has not been approved',
410
- });
411
- }
412
- const assemblyKey = yield this.getClaimAssemblyKey(sharedScenario.receiverPbkId, sharedScenario.claim.asReceiver.ciphers);
413
- // Decrypt all items
414
- const receiverDirectories = yield Promise.all(sharedScenario.receiverDirectories.map((x) => __awaiter(this, void 0, void 0, function* () {
415
- const wrappedItemKey = assemblyKey
416
- ? yield this.encryptionService.decrypt(assemblyKey, x.wrappedItemKey)
417
- : x.wrappedItemKey;
418
- return {
419
- receiverDirectoryId: x.id,
420
- receiverSharedKeyWrappedItemKey: wrappedItemKey,
421
- };
422
- })));
423
- yield this.lrApollo.mutate({
424
- mutation: ReceiveScenarioClaimMutation,
425
- variables: {
426
- input: {
427
- claimId,
428
- receiverDirectories,
429
- },
430
- },
431
- });
432
- });
433
- }
434
- getClaimAssemblyKey(keyId, ciphers) {
435
- return __awaiter(this, void 0, void 0, function* () {
436
- if (!ciphers || !ciphers.length)
437
- return null;
438
- let assemblyKeyParams;
439
- const shares = yield Promise.all(ciphers.map((x) => __awaiter(this, void 0, void 0, function* () {
440
- const { partialAssemblyKey } = yield this.keyGraph.decryptFromString(keyId, x);
441
- if (assemblyKeyParams) {
442
- if (JSON.stringify(assemblyKeyParams) !==
443
- JSON.stringify(partialAssemblyKey.assemblyKeyParams)) {
444
- throw new LrException({
445
- code: LrErrorCode.BadState,
446
- message: 'The assembly key parameters are different between the approvals.',
447
- });
448
- }
449
- }
450
- else {
451
- assemblyKeyParams = partialAssemblyKey.assemblyKeyParams;
452
- }
453
- return partialAssemblyKey.slip39.share.mnemonics;
454
- })));
455
- const rawAssemblyKey = yield this.slip39Service.recoverSecret(shares, ScenarioApproverService.SLIP39_PASSPHRASE);
456
- return yield KFS.asKey(Object.assign(Object.assign({}, assemblyKeyParams), { k: rawAssemblyKey }));
457
- });
458
- }
459
- resetScenario(scenarioId, disable = false) {
460
- return __awaiter(this, void 0, void 0, function* () {
461
- const prepareReceiverItem = (itemKeyId, sharedKeyId, assemblyKey) => __awaiter(this, void 0, void 0, function* () {
462
- const sharedKey = yield this.keyGraph.getKey(sharedKeyId);
463
- const itemKey = yield this.keyGraph.getKey(itemKeyId);
464
- let wrappedItemKey = yield this.keyGraph.encryptToString(sharedKey.jwk, itemKey.jwk.toJSON(true));
465
- if (assemblyKey) {
466
- wrappedItemKey = yield this.keyGraph.encryptToString(assemblyKey, wrappedItemKey);
467
- }
468
- return wrappedItemKey;
469
- });
470
- const prepareReceiverDirectories = (receiver, assemblyKey) => __awaiter(this, void 0, void 0, function* () {
471
- return Promise.all([
472
- ...receiver.categories.map((receiverDirectory) => __awaiter(this, void 0, void 0, function* () {
473
- return ({
474
- receiverDirectoryId: receiverDirectory.id,
475
- wrappedItemKey: yield prepareReceiverItem(receiverDirectory.category.keyId, receiver.keyId, assemblyKey),
476
- });
477
- })),
478
- ...receiver.records.map((receiverDirectory) => __awaiter(this, void 0, void 0, function* () {
479
- return ({
480
- receiverDirectoryId: receiverDirectory.id,
481
- wrappedItemKey: yield prepareReceiverItem(receiverDirectory.record.keyId, receiver.keyId, assemblyKey),
482
- });
483
- })),
484
- ]);
485
- });
486
- const prepareReceivers = (receivers, assemblyKey) => __awaiter(this, void 0, void 0, function* () {
487
- return Promise.all(receivers.map((receiver) => __awaiter(this, void 0, void 0, function* () {
488
- return ({
489
- receiverId: receiver.id,
490
- receiverDirectories: yield prepareReceiverDirectories(receiver, assemblyKey),
491
- receiverFiles: [],
492
- });
493
- })));
494
- });
495
- const prepareApprovers = (approvers) => __awaiter(this, void 0, void 0, function* () {
496
- return Promise.all(approvers.map((approver) => __awaiter(this, void 0, void 0, function* () {
497
- return ({
498
- approverId: approver.id,
499
- sharedKeyId: approver.keyId,
500
- });
501
- })));
502
- });
503
- const prepareSubAssemblies = (subAssemblies, assemblyKey) => __awaiter(this, void 0, void 0, function* () {
504
- return Promise.all(subAssemblies.map((sa) => __awaiter(this, void 0, void 0, function* () {
505
- return ({
506
- subAssemblyId: sa.id,
507
- subAssemblyCipherData: yield this.keyGraph.encryptToString(assemblyKey, { name: sa.name }),
508
- approvers: yield prepareApprovers(sa.approvers),
509
- });
510
- })));
511
- });
512
- // ------------------------------------------------------------------------------
513
- // ------------------------------------------------------------------------------
514
- // ------------------------------------------------------------------------------
515
- const scenario = yield this.getScenario(scenarioId);
516
- if (scenario.status !== ScenarioState.APPROVED) {
517
- throw new LrException({
518
- code: LrErrorCode.BadState,
519
- message: `Scenario must be in ${ScenarioState.APPROVED} state`,
520
- });
521
- }
522
- const subjectKey = yield this.keyGraph.getKey(scenario.keyId);
523
- const newAssemblyKey = yield this.keyFactory.createKey();
524
- const input = {
525
- scenarioId: scenario.id,
526
- disable,
527
- receivers: yield prepareReceivers(scenario.receivers, newAssemblyKey),
528
- };
529
- // Approver assembly
530
- const subjectKeyWrappedAssemblyKey = yield this.keyGraph.encryptToString(subjectKey.jwk, newAssemblyKey.toJSON(true));
531
- input.approverAssembly = {
532
- subjectKeyId: subjectKey.id,
533
- subjectKeyWrappedAssemblyKey,
534
- assemblyCipherData: '',
535
- subAssemblies: yield prepareSubAssemblies(scenario.approverGroups, newAssemblyKey),
536
- };
537
- if (scenario.approverGroups.length) {
538
- const _a = newAssemblyKey.toJSON(true), { k: rawAssemblyKey } = _a, assemblyKeyParams = __rest(_a, ["k"]);
539
- // Split the keys. If the scenario has been approved and there is an assembly setup, then
540
- // that assembly already enough members to meet quorum to approve the claim. So we can assume
541
- // that we can always do a key split here.
542
- const slipAssembly = new slip.Assembly(scenario.assemblyQuorum);
543
- scenario.approverGroups.forEach((sa, isa) => {
544
- let approverCount = sa.approvers.length;
545
- // if quorum is 1, then every approvers in the sub assembly shares the same partial key
546
- if (sa.quorum === 1) {
547
- approverCount = 1;
548
- }
549
- slipAssembly.addSubAssembly(new slip.SubAssembly(isa, sa.quorum, approverCount));
550
- });
551
- yield this.slip39Service.generateShares(rawAssemblyKey, ScenarioApproverService.SLIP39_PASSPHRASE, slipAssembly);
552
- // Copy the partial keys
553
- yield Promise.all(scenario.approverGroups.map((sa, isa) => __awaiter(this, void 0, void 0, function* () {
554
- const slipSubAssembly = slipAssembly.subAssemblies[isa];
555
- const inputSubAssembly = input.approverAssembly.subAssemblies[isa];
556
- yield Promise.all(sa.approvers.map((approver, ia) => __awaiter(this, void 0, void 0, function* () {
557
- const sharedKey = yield this.keyGraph.getKey(approver.keyId);
558
- // if quorum is 1, then every approvers in the sub assembly shares the same partial key
559
- const share = sa.quorum === 1
560
- ? slipSubAssembly.shares[0]
561
- : slipSubAssembly.shares[ia];
562
- const partialAssemblyKey = {
563
- slip39: {
564
- share,
565
- subAssembly: {
566
- quorum: sa.quorum,
567
- size: sa.approvers.length,
568
- },
569
- },
570
- assemblyKeyParams,
571
- };
572
- inputSubAssembly.approvers[ia].sharedCipherPartialAssemblyKey = yield this.keyGraph.encryptToString(sharedKey.jwk, partialAssemblyKey);
573
- })));
574
- })));
575
- }
576
- yield this.lrApollo.mutate({
577
- mutation: ResetScenarioMutation,
578
- variables: { input },
579
- });
580
- });
581
- }
582
- getAllScenarioIds() {
583
- return __awaiter(this, void 0, void 0, function* () {
584
- const { scenarios } = yield this.lrApollo.query({
585
- query: GetAllScenarioIdsQuery,
586
- });
587
- return scenarios.edges.map((edge) => edge.node.id);
588
- });
589
- }
590
- }
591
- ScenarioService.ɵprov = i0.ɵɵdefineInjectable({ factory: function ScenarioService_Factory() { return new ScenarioService(i0.ɵɵinject(i1.LrApolloService), i0.ɵɵinject(i2.KeyMetaService), i0.ɵɵinject(i3.KeyFactoryService), i0.ɵɵinject(i4.KeyService), i0.ɵɵinject(i5.EncryptionService), i0.ɵɵinject(i6.KeyGraphService), i0.ɵɵinject(i7.TrustedPartyService), i0.ɵɵinject(i8.Slip39Service), i0.ɵɵinject(i9.ScenarioClaimantService), i0.ɵɵinject(i10.ScenarioApproverService), i0.ɵɵinject(i11.ScenarioReceiverService), i0.ɵɵinject(i12.LrGraphQLService)); }, token: ScenarioService, providedIn: "root" });
592
- ScenarioService.decorators = [
593
- { type: Injectable, args: [{
594
- providedIn: 'root',
595
- },] }
596
- ];
597
- ScenarioService.ctorParameters = () => [
598
- { type: LrApolloService },
599
- { type: KeyMetaService },
600
- { type: KFS },
601
- { type: KeyService },
602
- { type: EncryptionService },
603
- { type: KeyGraphService },
604
- { type: TrustedPartyService },
605
- { type: slip.Slip39Service },
606
- { type: ScenarioClaimantService },
607
- { type: ScenarioApproverService },
608
- { type: ScenarioReceiverService },
609
- { type: LrGraphQLService }
610
- ];
611
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scenario.service.js","sourceRoot":"C:/Projects/newrepo/kc-client/projects/core/src/","sources":["lib/scenario/scenario.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { JWK } from 'node-jose';\r\nimport { LrApolloService } from '../api/lr-apollo.service';\r\nimport { CategoryFilter, RecordFilter } from '../category/category.gql';\r\nimport { EncryptionService } from '../cryptography/encryption.service';\r\nimport { KeyGraphService } from '../cryptography/key-graph.service';\r\nimport { KeyMetaService } from '../cryptography/key-meta.service';\r\nimport { KeyService } from '../cryptography/key.service';\r\nimport * as slip from '../cryptography/slip39.service';\r\nimport { RecordContentFilter } from '../record/record.gql';\r\nimport { TrustedPartyService } from '../trusted-parties/trusted-party.service';\r\nimport {\r\n  LrException,\r\n  LrErrorCode,\r\n  LrBadArgumentException,\r\n} from '../_common/exceptions';\r\nimport { ApprovalGroup, Approver } from './approvals/scenario-approval.types';\r\nimport { ScenarioApproverService } from './approvals/scenario-approver.service';\r\nimport { ScenarioClaimantService } from './claimants/scenario-claimant.service';\r\nimport { Claimant } from './claimants/scenario-claimant.types';\r\nimport { ScenarioReceiverService } from './receivers/scenario-receiver.service';\r\nimport { Receiver } from './receivers/scenario-receiver.types';\r\nimport {\r\n  ApproveScenarioClaimMutation,\r\n  CancelScenarioClaimMutation,\r\n  CreateScenarioClaimMutation,\r\n  CreateScenarioMutation,\r\n  DeleteScenarioMutation,\r\n  DisableScenarioMutation,\r\n  EnableScenarioMutation,\r\n  GetAllScenarioClaimsQuery,\r\n  GetAllScenariosQuery,\r\n  GetAllSharedScenariosQuery,\r\n  GetScenarioQuery,\r\n  GetSharedScenarioQuery,\r\n  GetTrustedPartyScenariosQuery,\r\n  ReceiveScenarioClaimMutation,\r\n  RejectScenarioClaimMutation,\r\n  ResetScenarioMutation,\r\n  UpdateScenarioMutation,\r\n  GetAllScenarioIdsQuery,\r\n} from './scenario.gql';\r\nimport {\r\n  CreateScenarioInput,\r\n  PartialAssemblyKey,\r\n  Scenario,\r\n  ScenarioClaim,\r\n  ScenarioState,\r\n  ScenarioSummary,\r\n  SharedScenario,\r\n  UpdateScenarioInput,\r\n  SharedScenarioClaimApprover,\r\n  ApproverClaimState,\r\n  SharedScenarioSummary,\r\n} from './scenario.types';\r\nimport * as moment_ from 'moment';\r\nimport { KeyFactoryService as KFS } from '../cryptography/key-factory.service';\r\nimport {\r\n  LrGraphQLService,\r\n  LrMergedMutation,\r\n  LrMutation,\r\n} from '../api/lr-graphql';\r\n\r\n// Ref: https://stackoverflow.com/questions/59735280/angular-8-moment-error-cannot-call-a-namespace-moment\r\nconst moment = moment_;\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class ScenarioService {\r\n  constructor(\r\n    private lrApollo: LrApolloService,\r\n    private keyMetaService: KeyMetaService,\r\n    private keyFactory: KFS,\r\n    private keyService: KeyService,\r\n    private encryptionService: EncryptionService,\r\n    private keyGraph: KeyGraphService,\r\n    private tpService: TrustedPartyService,\r\n    private slip39Service: slip.Slip39Service,\r\n    private scenarioClaimantService: ScenarioClaimantService,\r\n    private scenarioApproverService: ScenarioApproverService,\r\n    private scenarioReceiverService: ScenarioReceiverService,\r\n    private lrGraphQL: LrGraphQLService\r\n  ) {}\r\n\r\n  public async getMyScenarios(): Promise<ScenarioSummary[]> {\r\n    const { scenarios } = await this.lrApollo.query<any>({\r\n      query: GetAllScenariosQuery,\r\n    });\r\n    return await Promise.all(\r\n      scenarios.edges.map((x: any) => this.mapScenarioSummary(x.node))\r\n    );\r\n  }\r\n\r\n  private async mapScenarioSummary(scenario: any): Promise<ScenarioSummary> {\r\n    const { event, name } = await this.keyGraph.decryptFromString<{\r\n      event: string;\r\n      name: string;\r\n    }>(scenario.subjectKey.id, scenario.subjectCipherData);\r\n\r\n    return {\r\n      id: scenario.id,\r\n      name,\r\n      event,\r\n      status: scenario.state,\r\n      claimId: scenario.claim && scenario.claim.id,\r\n      claimStatus: scenario.claim && scenario.claim.state,\r\n      createdOn: scenario.created,\r\n      lastModified: scenario.modified,\r\n    };\r\n  }\r\n\r\n  public async getSharedScenarios(): Promise<SharedScenarioSummary[]> {\r\n    const { sharedScenarios } = await this.lrApollo.query<any>({\r\n      query: GetAllSharedScenariosQuery,\r\n    });\r\n    return (\r\n      await Promise.all<SharedScenario>(\r\n        sharedScenarios.edges.map((x: any) => this.mapSharedScenario(x.node))\r\n      )\r\n    ).filter((x) => x);\r\n  }\r\n\r\n  private async mapSharedScenarioSummary(\r\n    scenario: any\r\n  ): Promise<ScenarioSummary> {\r\n    const { event, name } = await this.keyGraph.decryptFromString<{\r\n      event: string;\r\n      name: string;\r\n    }>(scenario.subjectKey.id, scenario.subjectCipherData);\r\n\r\n    return {\r\n      id: scenario.id,\r\n      name,\r\n      event,\r\n      status: scenario.state,\r\n      claimId: scenario.claim && scenario.claim.id,\r\n      claimStatus: scenario.claim && scenario.claim.state,\r\n      createdOn: scenario.created,\r\n      lastModified: scenario.modified,\r\n    };\r\n  }\r\n\r\n  public async getSharedScenario(scenarioId: string): Promise<SharedScenario> {\r\n    const { sharedScenario } = await this.lrApollo.query<any>({\r\n      query: GetSharedScenarioQuery,\r\n      variables: {\r\n        id: scenarioId,\r\n      },\r\n    });\r\n    return await this.mapSharedScenario(sharedScenario);\r\n  }\r\n\r\n  private async mapSharedScenario(scenario: any): Promise<SharedScenario> {\r\n    try {\r\n      const claimantData = await this.getCipherData(scenario.asClaimant);\r\n      const receiverData = await this.getCipherData(scenario.asReceiver);\r\n      const approverData = await Promise.all<{\r\n        event?: string;\r\n        message?: string;\r\n      }>(\r\n        scenario.asApprovers.edges.map((x) =>\r\n          this.getCipherData(x.node.approver)\r\n        )\r\n      );\r\n\r\n      return {\r\n        id: scenario.id,\r\n        event:\r\n          claimantData.event ||\r\n          receiverData.event ||\r\n          approverData.map((x) => x.event)[0],\r\n        status: scenario.state,\r\n        trustedParty: await this.tpService.mapTrustedParty(scenario.tp),\r\n        isClaimant: !!scenario.asClaimant,\r\n        claimantMessage: claimantData.message,\r\n        isApprover: scenario.asApprovers.edges.length > 0,\r\n        approverMessages: approverData.map((x) => x.message),\r\n        isReceiver: !!scenario.asReceiver,\r\n        receiverMessage: receiverData.message,\r\n        receiverKeyId: scenario.asReceiver && scenario.asReceiver.sharedKey.id,\r\n        receiverPbkId: scenario.asReceiver && scenario.asReceiver.pbk.id,\r\n        receiverDirectories:\r\n          scenario.asReceiver &&\r\n          scenario.asReceiver.receiverDirectories.edges.map((x) => x.node),\r\n        claim: scenario.sharedClaim\r\n          ? {\r\n              id: scenario.sharedClaim.id,\r\n              isClaimant: scenario.sharedClaim.isClaimant,\r\n              status: scenario.sharedClaim.state,\r\n              asApprovers: await Promise.all<SharedScenarioClaimApprover>(\r\n                scenario.sharedClaim.asClaimApprovers.edges\r\n                  .map((x) => x.node)\r\n                  .map(async (x) => ({\r\n                    approverId: x.approver.id,\r\n                    approverKey: await this.getApproverKey(x.approver),\r\n                    status: x.state,\r\n                    receivers: x.receivers.edges.map((y) => ({\r\n                      id: y.node.id,\r\n                      pbkId: y.node.pbk.id,\r\n                    })),\r\n                  }))\r\n              ),\r\n              asReceiver: scenario.sharedClaim.asClaimReceiver\r\n                ? {\r\n                    received: scenario.sharedClaim.asClaimReceiver.received,\r\n                    ciphers: scenario.sharedClaim.asClaimReceiver.approvals.edges.map(\r\n                      (x) => x.node.receiverPbkCipher\r\n                    ),\r\n                  }\r\n                : null,\r\n            }\r\n          : null,\r\n      };\r\n    } catch (e) {\r\n      console.error('Failed to decrypt shared scenario.', e, scenario);\r\n      return null;\r\n    }\r\n  }\r\n\r\n  public async getTrustedPartyScenarios(\r\n    trustedPartyId: string\r\n  ): Promise<{\r\n    myScenarios: ScenarioSummary[];\r\n    sharedScenarios: SharedScenario[];\r\n  }> {\r\n    const { tp } = await this.lrApollo.query<any>({\r\n      query: GetTrustedPartyScenariosQuery,\r\n      variables: { partyId: trustedPartyId },\r\n    });\r\n    return {\r\n      myScenarios: await Promise.all(\r\n        tp.myScenarios.edges.map((x: any) => this.mapScenarioSummary(x.node))\r\n      ),\r\n      sharedScenarios: await Promise.all(\r\n        tp.sharedScenarios.edges.map((x: any) => this.mapSharedScenario(x.node))\r\n      ),\r\n    };\r\n  }\r\n\r\n  public async getScenarioClaims(): Promise<ScenarioClaim[]> {\r\n    const { scenarios } = await this.lrApollo.query<any>({\r\n      query: GetAllScenarioClaimsQuery,\r\n    });\r\n\r\n    const claims = await Promise.all<ScenarioClaim[]>(\r\n      scenarios.edges.map(async (x: any) => {\r\n        const scenario = await this.mapScenarioSummary(x.node);\r\n\r\n        return await Promise.all<ScenarioClaim>(\r\n          x.node.claims.edges.map(async (y) => ({\r\n            id: y.node.id,\r\n            state: y.node.state,\r\n            triggeredBy: await this.tpService.mapTrustedParty(\r\n              y.node.claimant.tp\r\n            ),\r\n            triggeredOn: y.node.created,\r\n            lastModified: y.node.modified,\r\n            scenario,\r\n          }))\r\n        );\r\n      })\r\n    );\r\n\r\n    return claims\r\n      .reduce((x, y) => [...x, ...y], [])\r\n      .sort(\r\n        (x, y) =>\r\n          -1 *\r\n          moment(new Date(x.lastModified)).diff(\r\n            moment(new Date(y.lastModified))\r\n          )\r\n      );\r\n  }\r\n\r\n  private async getCipherData(cipher?: {\r\n    sharedKey: { id: string };\r\n    sharedCipherData: string;\r\n  }): Promise<{ event?: string; message?: string }> {\r\n    if (!cipher) return {};\r\n\r\n    return await this.keyGraph.decryptFromString<{\r\n      event?: string;\r\n      message?: string;\r\n    }>(cipher.sharedKey.id, cipher.sharedCipherData);\r\n  }\r\n\r\n  private async getApproverKey(cipher?: {\r\n    sharedKey: { id: string };\r\n    sharedCipherPartialAssemblyKey: string;\r\n  }): Promise<string> {\r\n    if (!cipher) return null;\r\n\r\n    return await this.keyGraph.decryptFromString<string>(\r\n      cipher.sharedKey.id,\r\n      cipher.sharedCipherPartialAssemblyKey\r\n    );\r\n  }\r\n\r\n  public async getScenario(scenarioId: string): Promise<Scenario> {\r\n    const { scenario } = await this.lrApollo.query<any>({\r\n      query: GetScenarioQuery,\r\n      variables: {\r\n        id: scenarioId,\r\n        categoryFilter: CategoryFilter,\r\n        recordFilter: RecordFilter,\r\n        contentFilter: RecordContentFilter,\r\n      },\r\n    });\r\n    return await this.mapScenario(scenario);\r\n  }\r\n\r\n  private async mapScenario(scenario: any): Promise<Scenario> {\r\n    const { name, event } = await this.keyGraph.decryptFromString<{\r\n      event: string;\r\n      name: string;\r\n    }>(scenario.subjectKey.id, scenario.subjectCipherData);\r\n    const claimants = await Promise.all<Claimant>(\r\n      scenario.claimants.edges.map((x) =>\r\n        this.scenarioClaimantService.mapClaimant(x.node)\r\n      )\r\n    );\r\n\r\n    return {\r\n      id: scenario.id,\r\n      keyId: scenario.subjectKey.id,\r\n      assemblyKeyId:\r\n        scenario.approverAssembly && scenario.approverAssembly.assemblyKey.id,\r\n      assemblyQuorum:\r\n        scenario.approverAssembly && scenario.approverAssembly.quorum,\r\n      name,\r\n      event,\r\n      status: scenario.state,\r\n      claimants,\r\n      approverGroups: scenario.approverAssembly\r\n        ? await Promise.all(\r\n            scenario.approverAssembly.subAssemblies.edges.map((x) =>\r\n              this.scenarioApproverService.mapApproverGroup(x.node)\r\n            )\r\n          )\r\n        : [],\r\n      receivers: await Promise.all(\r\n        scenario.receivers.edges.map((x) =>\r\n          this.scenarioReceiverService.mapReceiver(x.node)\r\n        )\r\n      ),\r\n      claim: scenario.claim\r\n        ? {\r\n            id: scenario.claim.id,\r\n            status: scenario.claim.state,\r\n            claimant: claimants.find(\r\n              (x) => x.id === scenario.claim.claimant.id\r\n            ),\r\n          }\r\n        : null,\r\n    };\r\n  }\r\n\r\n  public async createScenario(input: CreateScenarioInput): Promise<string> {\r\n    const rootKey = await this.keyService.getCurrentRootKey();\r\n\r\n    const subjectKey = await this.keyFactory.createKey();\r\n    const rootKeyWrappedSubjectKey = await this.keyGraph.encryptToString(\r\n      rootKey.jwk,\r\n      subjectKey.toJSON(true)\r\n    );\r\n\r\n    const subjectCipherData = await this.keyGraph.encryptToString(\r\n      subjectKey,\r\n      input.plainSubjectCipherData\r\n    );\r\n\r\n    const { createScenario } = await this.lrApollo.mutate<any>({\r\n      mutation: CreateScenarioMutation,\r\n      variables: {\r\n        input: {\r\n          rootKeyId: rootKey.id,\r\n          rootKeyWrappedSubjectKey,\r\n          subjectCipherData,\r\n        },\r\n      },\r\n    });\r\n    return createScenario.scenario.id;\r\n  }\r\n\r\n  public async updateScenario(input: UpdateScenarioInput): Promise<void> {\r\n    await this.lrApollo.mutate<void>({\r\n      mutation: UpdateScenarioMutation,\r\n      variables: {\r\n        input: {\r\n          scenarioId: input.scenarioId,\r\n          subjectKeyId: input.keyId,\r\n          subjectCipherData: await this.keyGraph.encryptToString(\r\n            input.keyId,\r\n            input.plainSubjectCipherData\r\n          ),\r\n        },\r\n      },\r\n    });\r\n  }\r\n\r\n  public async enableScenario(scenarioId: string): Promise<void> {\r\n    await this.lrApollo.mutate<void>({\r\n      mutation: EnableScenarioMutation,\r\n      variables: { input: { scenarioId } },\r\n    });\r\n  }\r\n\r\n  public async disableScenario(scenarioId: string): Promise<void> {\r\n    await this.lrApollo.mutate<void>({\r\n      mutation: DisableScenarioMutation,\r\n      variables: { input: { scenarioId } },\r\n    });\r\n  }\r\n\r\n  public async deleteScenario(scenarioId: string): Promise<void> {\r\n    await this.lrApollo.mutate<void>({\r\n      mutation: DeleteScenarioMutation,\r\n      variables: { input: { scenarioId } },\r\n    });\r\n  }\r\n\r\n  public async createClaim(scenarioId: string): Promise<string> {\r\n    const res = await this.lrApollo.mutate<any>({\r\n      mutation: CreateScenarioClaimMutation,\r\n      variables: { input: { scenarioId } },\r\n    });\r\n    return res.createScenarioClaim.sharedClaim.id;\r\n  }\r\n\r\n  public async cancelClaim(claimId: string): Promise<void> {\r\n    await this.lrApollo.mutate<void>({\r\n      mutation: CancelScenarioClaimMutation,\r\n      variables: { input: { claimId } },\r\n    });\r\n  }\r\n\r\n  public async approveClaim(scenarioId: string, claimId: string) {\r\n    return this.lrGraphQL.lrMutate(\r\n      this.approveClaimMutation(scenarioId, claimId)\r\n    );\r\n  }\r\n\r\n  public async approveClaimMutation(scenarioId: string, claimId: string) {\r\n    const sharedScenario = await this.getSharedScenario(scenarioId);\r\n\r\n    // Double check the claim matches\r\n    if (sharedScenario.claim.id !== claimId) {\r\n      throw new LrException({\r\n        code: LrErrorCode.ReceiveClaimMismatch,\r\n        message:\r\n          'claimId does not match with the current claimId of the scenario',\r\n      });\r\n    }\r\n\r\n    const createMutation = async (asApprover: SharedScenarioClaimApprover) => {\r\n      return new LrMutation({\r\n        mutation: ApproveScenarioClaimMutation,\r\n        variables: {\r\n          input: {\r\n            claimId,\r\n            approverId: asApprover.approverId,\r\n            receivers: await Promise.all(\r\n              asApprover.receivers.map(async (y) => ({\r\n                receiverId: y.id,\r\n                receiverPbkCipher: await this.keyGraph.encryptToString(\r\n                  y.pbkId,\r\n                  { partialAssemblyKey: asApprover.approverKey }\r\n                ),\r\n              }))\r\n            ),\r\n          },\r\n        },\r\n      });\r\n    };\r\n\r\n    const mutations = sharedScenario.claim.asApprovers\r\n      .filter((asApprover) => asApprover.status === ApproverClaimState.Claimed)\r\n      .map((asApprover) => createMutation(asApprover));\r\n\r\n    return LrMergedMutation.create(await Promise.all(mutations));\r\n  }\r\n\r\n  public async rejectClaim(scenarioId: string, claimId: string) {\r\n    return this.lrGraphQL.lrMutate(\r\n      this.rejectClaimMutation(scenarioId, claimId)\r\n    );\r\n  }\r\n\r\n  public async rejectClaimMutation(scenarioId: string, claimId: string) {\r\n    const sharedScenario = await this.getSharedScenario(scenarioId);\r\n\r\n    // Double check the claim matches\r\n    if (sharedScenario.claim.id !== claimId) {\r\n      throw new LrException({\r\n        code: LrErrorCode.ReceiveClaimMismatch,\r\n        message:\r\n          'ClaimId does not match with the current claimId of the scenario',\r\n      });\r\n    }\r\n\r\n    const createMutation = async (asApprover: SharedScenarioClaimApprover) => {\r\n      return new LrMutation({\r\n        mutation: RejectScenarioClaimMutation,\r\n        variables: { input: { claimId, approverId: asApprover.approverId } },\r\n      });\r\n    };\r\n\r\n    const mutations = sharedScenario.claim.asApprovers\r\n      .filter((asApprover) => asApprover.status === ApproverClaimState.Claimed)\r\n      .map((asApprover) => createMutation(asApprover));\r\n\r\n    return LrMergedMutation.create(await Promise.all(mutations));\r\n  }\r\n\r\n  public async receiveClaim(\r\n    scenarioId: string,\r\n    claimId: string\r\n  ): Promise<void> {\r\n    // Get all the shared items\r\n    const sharedScenario = await this.getSharedScenario(scenarioId);\r\n\r\n    // Double check the claim matches\r\n    if (sharedScenario.claim.id !== claimId) {\r\n      throw new LrException({\r\n        code: LrErrorCode.ReceiveClaimMismatch,\r\n        message:\r\n          'ClaimId does not match with the current claimId of the scenario',\r\n      });\r\n    }\r\n    if (sharedScenario.status !== ScenarioState.APPROVED) {\r\n      throw new LrException({\r\n        code: LrErrorCode.BadState,\r\n        message: 'Scenario claim has not been approved',\r\n      });\r\n    }\r\n\r\n    const assemblyKey = await this.getClaimAssemblyKey(\r\n      sharedScenario.receiverPbkId,\r\n      sharedScenario.claim.asReceiver.ciphers\r\n    );\r\n\r\n    // Decrypt all items\r\n    const receiverDirectories = await Promise.all(\r\n      sharedScenario.receiverDirectories.map(async (x) => {\r\n        const wrappedItemKey = assemblyKey\r\n          ? await this.encryptionService.decrypt(assemblyKey, x.wrappedItemKey)\r\n          : x.wrappedItemKey;\r\n\r\n        return {\r\n          receiverDirectoryId: x.id,\r\n          receiverSharedKeyWrappedItemKey: wrappedItemKey, // the wrappedItemKey is already wrapped by receiverSharedKey\r\n        };\r\n      })\r\n    );\r\n\r\n    await this.lrApollo.mutate<void>({\r\n      mutation: ReceiveScenarioClaimMutation,\r\n      variables: {\r\n        input: {\r\n          claimId,\r\n          receiverDirectories,\r\n        },\r\n      },\r\n    });\r\n  }\r\n\r\n  private async getClaimAssemblyKey(keyId: string, ciphers: string[]) {\r\n    if (!ciphers || !ciphers.length) return null;\r\n\r\n    let assemblyKeyParams: object;\r\n\r\n    const shares = await Promise.all(\r\n      ciphers.map(async (x) => {\r\n        const { partialAssemblyKey } = await this.keyGraph.decryptFromString<{\r\n          partialAssemblyKey: PartialAssemblyKey;\r\n        }>(keyId, x);\r\n\r\n        if (assemblyKeyParams) {\r\n          if (\r\n            JSON.stringify(assemblyKeyParams) !==\r\n            JSON.stringify(partialAssemblyKey.assemblyKeyParams)\r\n          ) {\r\n            throw new LrException({\r\n              code: LrErrorCode.BadState,\r\n              message:\r\n                'The assembly key parameters are different between the approvals.',\r\n            });\r\n          }\r\n        } else {\r\n          assemblyKeyParams = partialAssemblyKey.assemblyKeyParams;\r\n        }\r\n        return partialAssemblyKey.slip39.share.mnemonics;\r\n      })\r\n    );\r\n\r\n    const rawAssemblyKey = await this.slip39Service.recoverSecret(\r\n      shares,\r\n      ScenarioApproverService.SLIP39_PASSPHRASE\r\n    );\r\n\r\n    return await KFS.asKey({\r\n      ...assemblyKeyParams,\r\n      k: rawAssemblyKey,\r\n    });\r\n  }\r\n\r\n  public async resetScenario(\r\n    scenarioId: string,\r\n    disable: boolean = false\r\n  ): Promise<void> {\r\n    const prepareReceiverItem = async (\r\n      itemKeyId: string,\r\n      sharedKeyId: string,\r\n      assemblyKey: JWK.Key\r\n    ): Promise<string> => {\r\n      const sharedKey = await this.keyGraph.getKey(sharedKeyId);\r\n      const itemKey = await this.keyGraph.getKey(itemKeyId);\r\n\r\n      let wrappedItemKey = await this.keyGraph.encryptToString(\r\n        sharedKey.jwk,\r\n        itemKey.jwk.toJSON(true)\r\n      );\r\n      if (assemblyKey) {\r\n        wrappedItemKey = await this.keyGraph.encryptToString(\r\n          assemblyKey,\r\n          wrappedItemKey\r\n        );\r\n      }\r\n      return wrappedItemKey;\r\n    };\r\n\r\n    const prepareReceiverDirectories = async (\r\n      receiver: Receiver,\r\n      assemblyKey: JWK.Key\r\n    ) => {\r\n      return Promise.all([\r\n        ...receiver.categories.map(async (receiverDirectory) => ({\r\n          receiverDirectoryId: receiverDirectory.id,\r\n          wrappedItemKey: await prepareReceiverItem(\r\n            receiverDirectory.category.keyId,\r\n            receiver.keyId,\r\n            assemblyKey\r\n          ),\r\n        })),\r\n        ...receiver.records.map(async (receiverDirectory) => ({\r\n          receiverDirectoryId: receiverDirectory.id,\r\n          wrappedItemKey: await prepareReceiverItem(\r\n            receiverDirectory.record.keyId,\r\n            receiver.keyId,\r\n            assemblyKey\r\n          ),\r\n        })),\r\n      ]);\r\n    };\r\n\r\n    const prepareReceivers = async (\r\n      receivers: Receiver[],\r\n      assemblyKey: JWK.Key\r\n    ) => {\r\n      return Promise.all(\r\n        receivers.map(async (receiver) => ({\r\n          receiverId: receiver.id,\r\n          receiverDirectories: await prepareReceiverDirectories(\r\n            receiver,\r\n            assemblyKey\r\n          ),\r\n          receiverFiles: [],\r\n        }))\r\n      );\r\n    };\r\n\r\n    const prepareApprovers = async (approvers: Approver[]) => {\r\n      return Promise.all(\r\n        approvers.map(async (approver) => ({\r\n          approverId: approver.id,\r\n          sharedKeyId: approver.keyId,\r\n        }))\r\n      );\r\n    };\r\n\r\n    const prepareSubAssemblies = async (\r\n      subAssemblies: ApprovalGroup[],\r\n      assemblyKey: JWK.Key\r\n    ) => {\r\n      return Promise.all(\r\n        subAssemblies.map(async (sa) => ({\r\n          subAssemblyId: sa.id,\r\n          subAssemblyCipherData: await this.keyGraph.encryptToString(\r\n            assemblyKey,\r\n            { name: sa.name }\r\n          ),\r\n          approvers: await prepareApprovers(sa.approvers),\r\n        }))\r\n      );\r\n    };\r\n\r\n    // ------------------------------------------------------------------------------\r\n    // ------------------------------------------------------------------------------\r\n    // ------------------------------------------------------------------------------\r\n\r\n    const scenario = await this.getScenario(scenarioId);\r\n    if (scenario.status !== ScenarioState.APPROVED) {\r\n      throw new LrException({\r\n        code: LrErrorCode.BadState,\r\n        message: `Scenario must be in ${ScenarioState.APPROVED} state`,\r\n      });\r\n    }\r\n\r\n    const subjectKey = await this.keyGraph.getKey(scenario.keyId);\r\n    const newAssemblyKey = await this.keyFactory.createKey();\r\n\r\n    const input: any = {\r\n      scenarioId: scenario.id,\r\n      disable,\r\n      receivers: await prepareReceivers(scenario.receivers, newAssemblyKey),\r\n    };\r\n\r\n    // Approver assembly\r\n    const subjectKeyWrappedAssemblyKey = await this.keyGraph.encryptToString(\r\n      subjectKey.jwk,\r\n      newAssemblyKey.toJSON(true)\r\n    );\r\n\r\n    input.approverAssembly = {\r\n      subjectKeyId: subjectKey.id,\r\n      subjectKeyWrappedAssemblyKey,\r\n      assemblyCipherData: '',\r\n      subAssemblies: await prepareSubAssemblies(\r\n        scenario.approverGroups,\r\n        newAssemblyKey\r\n      ),\r\n    };\r\n\r\n    if (scenario.approverGroups.length) {\r\n      const { k: rawAssemblyKey, ...assemblyKeyParams } = newAssemblyKey.toJSON(\r\n        true\r\n      ) as any;\r\n\r\n      // Split the keys. If the scenario has been approved and there is an assembly setup, then\r\n      // that assembly already enough members to meet quorum to approve the claim. So we can assume\r\n      // that we can always do a key split here.\r\n      const slipAssembly = new slip.Assembly(scenario.assemblyQuorum);\r\n\r\n      scenario.approverGroups.forEach((sa, isa) => {\r\n        let approverCount = sa.approvers.length;\r\n        // if quorum is 1, then every approvers in the sub assembly shares the same partial key\r\n        if (sa.quorum === 1) {\r\n          approverCount = 1;\r\n        }\r\n        slipAssembly.addSubAssembly(\r\n          new slip.SubAssembly(isa, sa.quorum, approverCount)\r\n        );\r\n      });\r\n\r\n      await this.slip39Service.generateShares(\r\n        rawAssemblyKey,\r\n        ScenarioApproverService.SLIP39_PASSPHRASE,\r\n        slipAssembly\r\n      );\r\n\r\n      // Copy the partial keys\r\n      await Promise.all(\r\n        scenario.approverGroups.map(async (sa, isa) => {\r\n          const slipSubAssembly = slipAssembly.subAssemblies[isa];\r\n          const inputSubAssembly = input.approverAssembly.subAssemblies[isa];\r\n\r\n          await Promise.all(\r\n            sa.approvers.map(async (approver, ia) => {\r\n              const sharedKey = await this.keyGraph.getKey(approver.keyId);\r\n\r\n              // if quorum is 1, then every approvers in the sub assembly shares the same partial key\r\n              const share =\r\n                sa.quorum === 1\r\n                  ? slipSubAssembly.shares[0]\r\n                  : slipSubAssembly.shares[ia];\r\n\r\n              const partialAssemblyKey: PartialAssemblyKey = {\r\n                slip39: {\r\n                  share,\r\n                  subAssembly: {\r\n                    quorum: sa.quorum,\r\n                    size: sa.approvers.length,\r\n                  },\r\n                },\r\n                assemblyKeyParams,\r\n              };\r\n              inputSubAssembly.approvers[\r\n                ia\r\n              ].sharedCipherPartialAssemblyKey = await this.keyGraph.encryptToString(\r\n                sharedKey.jwk,\r\n                partialAssemblyKey\r\n              );\r\n            })\r\n          );\r\n        })\r\n      );\r\n    }\r\n    await this.lrApollo.mutate<any>({\r\n      mutation: ResetScenarioMutation,\r\n      variables: { input },\r\n    });\r\n  }\r\n\r\n  public async getAllScenarioIds(): Promise<string[]> {\r\n    const { scenarios } = await this.lrApollo.query<any>({\r\n      query: GetAllScenarioIdsQuery,\r\n    });\r\n    return scenarios.edges.map((edge) => edge.node.id);\r\n  }\r\n}\r\n"]}
1
+ import { __awaiter, __rest } from "tslib";
2
+ import { Injectable } from '@angular/core';
3
+ import { LrApolloService } from '../api/lr-apollo.service';
4
+ import { CategoryFilter, RecordFilter } from '../category/category.gql';
5
+ import { EncryptionService } from '../cryptography/encryption.service';
6
+ import { KeyGraphService } from '../cryptography/key-graph.service';
7
+ import { KeyMetaService } from '../cryptography/key-meta.service';
8
+ import { KeyService } from '../cryptography/key.service';
9
+ import * as slip from '../cryptography/slip39.service';
10
+ import { RecordContentFilter } from '../record/record.gql';
11
+ import { TrustedPartyService } from '../trusted-parties/trusted-party.service';
12
+ import { LrException, LrErrorCode, } from '../_common/exceptions';
13
+ import { ScenarioApproverService } from './approvals/scenario-approver.service';
14
+ import { ScenarioClaimantService } from './claimants/scenario-claimant.service';
15
+ import { ScenarioReceiverService } from './receivers/scenario-receiver.service';
16
+ import { ApproveScenarioClaimMutation, CancelScenarioClaimMutation, CreateScenarioClaimMutation, CreateScenarioMutation, DeleteScenarioMutation, DisableScenarioMutation, EnableScenarioMutation, GetAllScenarioClaimsQuery, GetAllScenariosQuery, GetAllSharedScenariosQuery, GetScenarioQuery, GetSharedScenarioQuery, GetTrustedPartyScenariosQuery, ReceiveScenarioClaimMutation, RejectScenarioClaimMutation, ResetScenarioMutation, UpdateScenarioMutation, GetAllScenarioIdsQuery, } from './scenario.gql';
17
+ import { ScenarioState, ApproverClaimState, } from './scenario.types';
18
+ import * as moment_ from 'moment';
19
+ import { KeyFactoryService as KFS } from '../cryptography/key-factory.service';
20
+ import { LrGraphQLService, LrMergedMutation, LrMutation, } from '../api/lr-graphql';
21
+ import * as i0 from "@angular/core";
22
+ import * as i1 from "../api/lr-apollo.service";
23
+ import * as i2 from "../cryptography/key-meta.service";
24
+ import * as i3 from "../cryptography/key-factory.service";
25
+ import * as i4 from "../cryptography/key.service";
26
+ import * as i5 from "../cryptography/encryption.service";
27
+ import * as i6 from "../cryptography/key-graph.service";
28
+ import * as i7 from "../trusted-parties/trusted-party.service";
29
+ import * as i8 from "../cryptography/slip39.service";
30
+ import * as i9 from "./claimants/scenario-claimant.service";
31
+ import * as i10 from "./approvals/scenario-approver.service";
32
+ import * as i11 from "./receivers/scenario-receiver.service";
33
+ import * as i12 from "../api/lr-graphql/lr-graphql.service";
34
+ // Ref: https://stackoverflow.com/questions/59735280/angular-8-moment-error-cannot-call-a-namespace-moment
35
+ const moment = moment_;
36
+ export class ScenarioService {
37
+ constructor(lrApollo, keyMetaService, keyFactory, keyService, encryptionService, keyGraph, tpService, slip39Service, scenarioClaimantService, scenarioApproverService, scenarioReceiverService, lrGraphQL) {
38
+ this.lrApollo = lrApollo;
39
+ this.keyMetaService = keyMetaService;
40
+ this.keyFactory = keyFactory;
41
+ this.keyService = keyService;
42
+ this.encryptionService = encryptionService;
43
+ this.keyGraph = keyGraph;
44
+ this.tpService = tpService;
45
+ this.slip39Service = slip39Service;
46
+ this.scenarioClaimantService = scenarioClaimantService;
47
+ this.scenarioApproverService = scenarioApproverService;
48
+ this.scenarioReceiverService = scenarioReceiverService;
49
+ this.lrGraphQL = lrGraphQL;
50
+ }
51
+ getMyScenarios() {
52
+ return __awaiter(this, void 0, void 0, function* () {
53
+ const { scenarios } = yield this.lrApollo.query({
54
+ query: GetAllScenariosQuery,
55
+ });
56
+ return yield Promise.all(scenarios.edges.map((x) => this.mapScenarioSummary(x.node)));
57
+ });
58
+ }
59
+ mapScenarioSummary(scenario) {
60
+ return __awaiter(this, void 0, void 0, function* () {
61
+ const { event, name } = yield this.keyGraph.decryptFromString(scenario.subjectKey.id, scenario.subjectCipherData);
62
+ return {
63
+ id: scenario.id,
64
+ name,
65
+ event,
66
+ status: scenario.state,
67
+ claimId: scenario.claim && scenario.claim.id,
68
+ claimStatus: scenario.claim && scenario.claim.state,
69
+ createdOn: scenario.created,
70
+ lastModified: scenario.modified,
71
+ };
72
+ });
73
+ }
74
+ getSharedScenarios() {
75
+ return __awaiter(this, void 0, void 0, function* () {
76
+ const { sharedScenarios } = yield this.lrApollo.query({
77
+ query: GetAllSharedScenariosQuery,
78
+ });
79
+ return (yield Promise.all(sharedScenarios.edges.map((x) => this.mapSharedScenario(x.node)))).filter((x) => x);
80
+ });
81
+ }
82
+ mapSharedScenarioSummary(scenario) {
83
+ return __awaiter(this, void 0, void 0, function* () {
84
+ const { event, name } = yield this.keyGraph.decryptFromString(scenario.subjectKey.id, scenario.subjectCipherData);
85
+ return {
86
+ id: scenario.id,
87
+ name,
88
+ event,
89
+ status: scenario.state,
90
+ claimId: scenario.claim && scenario.claim.id,
91
+ claimStatus: scenario.claim && scenario.claim.state,
92
+ createdOn: scenario.created,
93
+ lastModified: scenario.modified,
94
+ };
95
+ });
96
+ }
97
+ getSharedScenario(scenarioId) {
98
+ return __awaiter(this, void 0, void 0, function* () {
99
+ const { sharedScenario } = yield this.lrApollo.query({
100
+ query: GetSharedScenarioQuery,
101
+ variables: {
102
+ id: scenarioId,
103
+ },
104
+ });
105
+ return yield this.mapSharedScenario(sharedScenario);
106
+ });
107
+ }
108
+ mapSharedScenario(scenario) {
109
+ return __awaiter(this, void 0, void 0, function* () {
110
+ try {
111
+ const claimantData = yield this.getCipherData(scenario.asClaimant);
112
+ const receiverData = yield this.getCipherData(scenario.asReceiver);
113
+ const approverData = yield Promise.all(scenario.asApprovers.edges.map((x) => this.getCipherData(x.node.approver)));
114
+ return {
115
+ id: scenario.id,
116
+ event: claimantData.event ||
117
+ receiverData.event ||
118
+ approverData.map((x) => x.event)[0],
119
+ status: scenario.state,
120
+ trustedParty: yield this.tpService.mapTrustedParty(scenario.tp),
121
+ isClaimant: !!scenario.asClaimant,
122
+ claimantMessage: claimantData.message,
123
+ isApprover: scenario.asApprovers.edges.length > 0,
124
+ approverMessages: approverData.map((x) => x.message),
125
+ isReceiver: !!scenario.asReceiver,
126
+ receiverMessage: receiverData.message,
127
+ receiverKeyId: scenario.asReceiver && scenario.asReceiver.sharedKey.id,
128
+ receiverPbkId: scenario.asReceiver && scenario.asReceiver.pbk.id,
129
+ receiverDirectories: scenario.asReceiver &&
130
+ scenario.asReceiver.receiverDirectories.edges.map((x) => x.node),
131
+ claim: scenario.sharedClaim
132
+ ? {
133
+ id: scenario.sharedClaim.id,
134
+ isClaimant: scenario.sharedClaim.isClaimant,
135
+ status: scenario.sharedClaim.state,
136
+ asApprovers: yield Promise.all(scenario.sharedClaim.asClaimApprovers.edges
137
+ .map((x) => x.node)
138
+ .map((x) => __awaiter(this, void 0, void 0, function* () {
139
+ return ({
140
+ approverId: x.approver.id,
141
+ approverKey: yield this.getApproverKey(x.approver),
142
+ status: x.state,
143
+ receivers: x.receivers.edges.map((y) => ({
144
+ id: y.node.id,
145
+ pbkId: y.node.pbk.id,
146
+ })),
147
+ });
148
+ }))),
149
+ asReceiver: scenario.sharedClaim.asClaimReceiver
150
+ ? {
151
+ received: scenario.sharedClaim.asClaimReceiver.received,
152
+ ciphers: scenario.sharedClaim.asClaimReceiver.approvals.edges.map((x) => x.node.receiverPbkCipher),
153
+ }
154
+ : null,
155
+ }
156
+ : null,
157
+ };
158
+ }
159
+ catch (e) {
160
+ console.error('Failed to decrypt shared scenario.', e, scenario);
161
+ return null;
162
+ }
163
+ });
164
+ }
165
+ getTrustedPartyScenarios(trustedPartyId) {
166
+ return __awaiter(this, void 0, void 0, function* () {
167
+ const { tp } = yield this.lrApollo.query({
168
+ query: GetTrustedPartyScenariosQuery,
169
+ variables: { partyId: trustedPartyId },
170
+ });
171
+ return {
172
+ myScenarios: yield Promise.all(tp.myScenarios.edges.map((x) => this.mapScenarioSummary(x.node))),
173
+ sharedScenarios: yield Promise.all(tp.sharedScenarios.edges.map((x) => this.mapSharedScenario(x.node))),
174
+ };
175
+ });
176
+ }
177
+ getScenarioClaims() {
178
+ return __awaiter(this, void 0, void 0, function* () {
179
+ const { scenarios } = yield this.lrApollo.query({
180
+ query: GetAllScenarioClaimsQuery,
181
+ });
182
+ const claims = yield Promise.all(scenarios.edges.map((x) => __awaiter(this, void 0, void 0, function* () {
183
+ const scenario = yield this.mapScenarioSummary(x.node);
184
+ return yield Promise.all(x.node.claims.edges.map((y) => __awaiter(this, void 0, void 0, function* () {
185
+ return ({
186
+ id: y.node.id,
187
+ state: y.node.state,
188
+ triggeredBy: yield this.tpService.mapTrustedParty(y.node.claimant.tp),
189
+ triggeredOn: y.node.created,
190
+ lastModified: y.node.modified,
191
+ scenario,
192
+ });
193
+ })));
194
+ })));
195
+ return claims
196
+ .reduce((x, y) => [...x, ...y], [])
197
+ .sort((x, y) => -1 *
198
+ moment(new Date(x.lastModified)).diff(moment(new Date(y.lastModified))));
199
+ });
200
+ }
201
+ getCipherData(cipher) {
202
+ return __awaiter(this, void 0, void 0, function* () {
203
+ if (!cipher)
204
+ return {};
205
+ return yield this.keyGraph.decryptFromString(cipher.sharedKey.id, cipher.sharedCipherData);
206
+ });
207
+ }
208
+ getApproverKey(cipher) {
209
+ return __awaiter(this, void 0, void 0, function* () {
210
+ if (!cipher)
211
+ return null;
212
+ return yield this.keyGraph.decryptFromString(cipher.sharedKey.id, cipher.sharedCipherPartialAssemblyKey);
213
+ });
214
+ }
215
+ getScenario(scenarioId) {
216
+ return __awaiter(this, void 0, void 0, function* () {
217
+ const { scenario } = yield this.lrApollo.query({
218
+ query: GetScenarioQuery,
219
+ variables: {
220
+ id: scenarioId,
221
+ categoryFilter: CategoryFilter,
222
+ recordFilter: RecordFilter,
223
+ contentFilter: RecordContentFilter,
224
+ },
225
+ });
226
+ return yield this.mapScenario(scenario);
227
+ });
228
+ }
229
+ mapScenario(scenario) {
230
+ return __awaiter(this, void 0, void 0, function* () {
231
+ const { name, event } = yield this.keyGraph.decryptFromString(scenario.subjectKey.id, scenario.subjectCipherData);
232
+ const claimants = yield Promise.all(scenario.claimants.edges.map((x) => this.scenarioClaimantService.mapClaimant(x.node)));
233
+ return {
234
+ id: scenario.id,
235
+ keyId: scenario.subjectKey.id,
236
+ assemblyKeyId: scenario.approverAssembly && scenario.approverAssembly.assemblyKey.id,
237
+ assemblyQuorum: scenario.approverAssembly && scenario.approverAssembly.quorum,
238
+ name,
239
+ event,
240
+ status: scenario.state,
241
+ claimants,
242
+ approverGroups: scenario.approverAssembly
243
+ ? yield Promise.all(scenario.approverAssembly.subAssemblies.edges.map((x) => this.scenarioApproverService.mapApproverGroup(x.node)))
244
+ : [],
245
+ receivers: yield Promise.all(scenario.receivers.edges.map((x) => this.scenarioReceiverService.mapReceiver(x.node))),
246
+ claim: scenario.claim
247
+ ? {
248
+ id: scenario.claim.id,
249
+ status: scenario.claim.state,
250
+ claimant: claimants.find((x) => x.id === scenario.claim.claimant.id),
251
+ }
252
+ : null,
253
+ };
254
+ });
255
+ }
256
+ createScenario(input) {
257
+ return __awaiter(this, void 0, void 0, function* () {
258
+ const rootKey = yield this.keyService.getCurrentRootKey();
259
+ const subjectKey = yield this.keyFactory.createKey();
260
+ const rootKeyWrappedSubjectKey = yield this.keyGraph.encryptToString(rootKey.jwk, subjectKey.toJSON(true));
261
+ const subjectCipherData = yield this.keyGraph.encryptToString(subjectKey, input.plainSubjectCipherData);
262
+ const { createScenario } = yield this.lrApollo.mutate({
263
+ mutation: CreateScenarioMutation,
264
+ variables: {
265
+ input: {
266
+ rootKeyId: rootKey.id,
267
+ rootKeyWrappedSubjectKey,
268
+ subjectCipherData,
269
+ },
270
+ },
271
+ });
272
+ return createScenario.scenario.id;
273
+ });
274
+ }
275
+ updateScenario(input) {
276
+ return __awaiter(this, void 0, void 0, function* () {
277
+ yield this.lrApollo.mutate({
278
+ mutation: UpdateScenarioMutation,
279
+ variables: {
280
+ input: {
281
+ scenarioId: input.scenarioId,
282
+ subjectKeyId: input.keyId,
283
+ subjectCipherData: yield this.keyGraph.encryptToString(input.keyId, input.plainSubjectCipherData),
284
+ },
285
+ },
286
+ });
287
+ });
288
+ }
289
+ enableScenario(scenarioId) {
290
+ return __awaiter(this, void 0, void 0, function* () {
291
+ yield this.lrApollo.mutate({
292
+ mutation: EnableScenarioMutation,
293
+ variables: { input: { scenarioId } },
294
+ });
295
+ });
296
+ }
297
+ disableScenario(scenarioId) {
298
+ return __awaiter(this, void 0, void 0, function* () {
299
+ yield this.lrApollo.mutate({
300
+ mutation: DisableScenarioMutation,
301
+ variables: { input: { scenarioId } },
302
+ });
303
+ });
304
+ }
305
+ deleteScenario(scenarioId) {
306
+ return __awaiter(this, void 0, void 0, function* () {
307
+ yield this.lrApollo.mutate({
308
+ mutation: DeleteScenarioMutation,
309
+ variables: { input: { scenarioId } },
310
+ });
311
+ });
312
+ }
313
+ createClaim(scenarioId) {
314
+ return __awaiter(this, void 0, void 0, function* () {
315
+ const res = yield this.lrApollo.mutate({
316
+ mutation: CreateScenarioClaimMutation,
317
+ variables: { input: { scenarioId } },
318
+ });
319
+ return res.createScenarioClaim.sharedClaim.id;
320
+ });
321
+ }
322
+ cancelClaim(claimId) {
323
+ return __awaiter(this, void 0, void 0, function* () {
324
+ yield this.lrApollo.mutate({
325
+ mutation: CancelScenarioClaimMutation,
326
+ variables: { input: { claimId } },
327
+ });
328
+ });
329
+ }
330
+ approveClaim(scenarioId, claimId) {
331
+ return __awaiter(this, void 0, void 0, function* () {
332
+ return this.lrGraphQL.lrMutate(this.approveClaimMutation(scenarioId, claimId));
333
+ });
334
+ }
335
+ approveClaimMutation(scenarioId, claimId) {
336
+ return __awaiter(this, void 0, void 0, function* () {
337
+ const sharedScenario = yield this.getSharedScenario(scenarioId);
338
+ // Double check the claim matches
339
+ if (sharedScenario.claim.id !== claimId) {
340
+ throw new LrException({
341
+ code: LrErrorCode.ReceiveClaimMismatch,
342
+ message: 'claimId does not match with the current claimId of the scenario',
343
+ });
344
+ }
345
+ const createMutation = (asApprover) => __awaiter(this, void 0, void 0, function* () {
346
+ return new LrMutation({
347
+ mutation: ApproveScenarioClaimMutation,
348
+ variables: {
349
+ input: {
350
+ claimId,
351
+ approverId: asApprover.approverId,
352
+ receivers: yield Promise.all(asApprover.receivers.map((y) => __awaiter(this, void 0, void 0, function* () {
353
+ return ({
354
+ receiverId: y.id,
355
+ receiverPbkCipher: yield this.keyGraph.encryptToString(y.pbkId, { partialAssemblyKey: asApprover.approverKey }),
356
+ });
357
+ }))),
358
+ },
359
+ },
360
+ });
361
+ });
362
+ const mutations = sharedScenario.claim.asApprovers
363
+ .filter((asApprover) => asApprover.status === ApproverClaimState.Claimed)
364
+ .map((asApprover) => createMutation(asApprover));
365
+ return LrMergedMutation.create(yield Promise.all(mutations));
366
+ });
367
+ }
368
+ rejectClaim(scenarioId, claimId) {
369
+ return __awaiter(this, void 0, void 0, function* () {
370
+ return this.lrGraphQL.lrMutate(this.rejectClaimMutation(scenarioId, claimId));
371
+ });
372
+ }
373
+ rejectClaimMutation(scenarioId, claimId) {
374
+ return __awaiter(this, void 0, void 0, function* () {
375
+ const sharedScenario = yield this.getSharedScenario(scenarioId);
376
+ // Double check the claim matches
377
+ if (sharedScenario.claim.id !== claimId) {
378
+ throw new LrException({
379
+ code: LrErrorCode.ReceiveClaimMismatch,
380
+ message: 'ClaimId does not match with the current claimId of the scenario',
381
+ });
382
+ }
383
+ const createMutation = (asApprover) => __awaiter(this, void 0, void 0, function* () {
384
+ return new LrMutation({
385
+ mutation: RejectScenarioClaimMutation,
386
+ variables: { input: { claimId, approverId: asApprover.approverId } },
387
+ });
388
+ });
389
+ const mutations = sharedScenario.claim.asApprovers
390
+ .filter((asApprover) => asApprover.status === ApproverClaimState.Claimed)
391
+ .map((asApprover) => createMutation(asApprover));
392
+ return LrMergedMutation.create(yield Promise.all(mutations));
393
+ });
394
+ }
395
+ receiveClaim(scenarioId, claimId) {
396
+ return __awaiter(this, void 0, void 0, function* () {
397
+ // Get all the shared items
398
+ const sharedScenario = yield this.getSharedScenario(scenarioId);
399
+ // Double check the claim matches
400
+ if (sharedScenario.claim.id !== claimId) {
401
+ throw new LrException({
402
+ code: LrErrorCode.ReceiveClaimMismatch,
403
+ message: 'ClaimId does not match with the current claimId of the scenario',
404
+ });
405
+ }
406
+ if (sharedScenario.status !== ScenarioState.APPROVED) {
407
+ throw new LrException({
408
+ code: LrErrorCode.BadState,
409
+ message: 'Scenario claim has not been approved',
410
+ });
411
+ }
412
+ const assemblyKey = yield this.getClaimAssemblyKey(sharedScenario.receiverPbkId, sharedScenario.claim.asReceiver.ciphers);
413
+ // Decrypt all items
414
+ const receiverDirectories = yield Promise.all(sharedScenario.receiverDirectories.map((x) => __awaiter(this, void 0, void 0, function* () {
415
+ const wrappedItemKey = assemblyKey
416
+ ? yield this.encryptionService.decrypt(assemblyKey, x.wrappedItemKey)
417
+ : x.wrappedItemKey;
418
+ return {
419
+ receiverDirectoryId: x.id,
420
+ receiverSharedKeyWrappedItemKey: wrappedItemKey,
421
+ };
422
+ })));
423
+ yield this.lrApollo.mutate({
424
+ mutation: ReceiveScenarioClaimMutation,
425
+ variables: {
426
+ input: {
427
+ claimId,
428
+ receiverDirectories,
429
+ },
430
+ },
431
+ });
432
+ });
433
+ }
434
+ getClaimAssemblyKey(keyId, ciphers) {
435
+ return __awaiter(this, void 0, void 0, function* () {
436
+ if (!ciphers || !ciphers.length)
437
+ return null;
438
+ let assemblyKeyParams;
439
+ const shares = yield Promise.all(ciphers.map((x) => __awaiter(this, void 0, void 0, function* () {
440
+ const { partialAssemblyKey } = yield this.keyGraph.decryptFromString(keyId, x);
441
+ if (assemblyKeyParams) {
442
+ if (JSON.stringify(assemblyKeyParams) !==
443
+ JSON.stringify(partialAssemblyKey.assemblyKeyParams)) {
444
+ throw new LrException({
445
+ code: LrErrorCode.BadState,
446
+ message: 'The assembly key parameters are different between the approvals.',
447
+ });
448
+ }
449
+ }
450
+ else {
451
+ assemblyKeyParams = partialAssemblyKey.assemblyKeyParams;
452
+ }
453
+ return partialAssemblyKey.slip39.share.mnemonics;
454
+ })));
455
+ const rawAssemblyKey = yield this.slip39Service.recoverSecret(shares, ScenarioApproverService.SLIP39_PASSPHRASE);
456
+ return yield KFS.asKey(Object.assign(Object.assign({}, assemblyKeyParams), { k: rawAssemblyKey }));
457
+ });
458
+ }
459
+ resetScenario(scenarioId, disable = false) {
460
+ return __awaiter(this, void 0, void 0, function* () {
461
+ const prepareReceiverItem = (itemKeyId, sharedKeyId, assemblyKey) => __awaiter(this, void 0, void 0, function* () {
462
+ const sharedKey = yield this.keyGraph.getKey(sharedKeyId);
463
+ const itemKey = yield this.keyGraph.getKey(itemKeyId);
464
+ let wrappedItemKey = yield this.keyGraph.encryptToString(sharedKey.jwk, itemKey.jwk.toJSON(true));
465
+ if (assemblyKey) {
466
+ wrappedItemKey = yield this.keyGraph.encryptToString(assemblyKey, wrappedItemKey);
467
+ }
468
+ return wrappedItemKey;
469
+ });
470
+ const prepareReceiverDirectories = (receiver, assemblyKey) => __awaiter(this, void 0, void 0, function* () {
471
+ return Promise.all([
472
+ ...receiver.categories.map((receiverDirectory) => __awaiter(this, void 0, void 0, function* () {
473
+ return ({
474
+ receiverDirectoryId: receiverDirectory.id,
475
+ wrappedItemKey: yield prepareReceiverItem(receiverDirectory.category.keyId, receiver.keyId, assemblyKey),
476
+ });
477
+ })),
478
+ ...receiver.records.map((receiverDirectory) => __awaiter(this, void 0, void 0, function* () {
479
+ return ({
480
+ receiverDirectoryId: receiverDirectory.id,
481
+ wrappedItemKey: yield prepareReceiverItem(receiverDirectory.record.keyId, receiver.keyId, assemblyKey),
482
+ });
483
+ })),
484
+ ]);
485
+ });
486
+ const prepareReceivers = (receivers, assemblyKey) => __awaiter(this, void 0, void 0, function* () {
487
+ return Promise.all(receivers.map((receiver) => __awaiter(this, void 0, void 0, function* () {
488
+ return ({
489
+ receiverId: receiver.id,
490
+ receiverDirectories: yield prepareReceiverDirectories(receiver, assemblyKey),
491
+ receiverFiles: [],
492
+ });
493
+ })));
494
+ });
495
+ const prepareApprovers = (approvers) => __awaiter(this, void 0, void 0, function* () {
496
+ return Promise.all(approvers.map((approver) => __awaiter(this, void 0, void 0, function* () {
497
+ return ({
498
+ approverId: approver.id,
499
+ sharedKeyId: approver.keyId,
500
+ });
501
+ })));
502
+ });
503
+ const prepareSubAssemblies = (subAssemblies, assemblyKey) => __awaiter(this, void 0, void 0, function* () {
504
+ return Promise.all(subAssemblies.map((sa) => __awaiter(this, void 0, void 0, function* () {
505
+ return ({
506
+ subAssemblyId: sa.id,
507
+ subAssemblyCipherData: yield this.keyGraph.encryptToString(assemblyKey, { name: sa.name }),
508
+ approvers: yield prepareApprovers(sa.approvers),
509
+ });
510
+ })));
511
+ });
512
+ // ------------------------------------------------------------------------------
513
+ // ------------------------------------------------------------------------------
514
+ // ------------------------------------------------------------------------------
515
+ const scenario = yield this.getScenario(scenarioId);
516
+ if (scenario.status !== ScenarioState.APPROVED) {
517
+ throw new LrException({
518
+ code: LrErrorCode.BadState,
519
+ message: `Scenario must be in ${ScenarioState.APPROVED} state`,
520
+ });
521
+ }
522
+ const subjectKey = yield this.keyGraph.getKey(scenario.keyId);
523
+ const newAssemblyKey = yield this.keyFactory.createKey();
524
+ const input = {
525
+ scenarioId: scenario.id,
526
+ disable,
527
+ receivers: yield prepareReceivers(scenario.receivers, newAssemblyKey),
528
+ };
529
+ // Approver assembly
530
+ const subjectKeyWrappedAssemblyKey = yield this.keyGraph.encryptToString(subjectKey.jwk, newAssemblyKey.toJSON(true));
531
+ input.approverAssembly = {
532
+ subjectKeyId: subjectKey.id,
533
+ subjectKeyWrappedAssemblyKey,
534
+ assemblyCipherData: '',
535
+ subAssemblies: yield prepareSubAssemblies(scenario.approverGroups, newAssemblyKey),
536
+ };
537
+ if (scenario.approverGroups.length) {
538
+ const _a = newAssemblyKey.toJSON(true), { k: rawAssemblyKey } = _a, assemblyKeyParams = __rest(_a, ["k"]);
539
+ // Split the keys. If the scenario has been approved and there is an assembly setup, then
540
+ // that assembly already enough members to meet quorum to approve the claim. So we can assume
541
+ // that we can always do a key split here.
542
+ const slipAssembly = new slip.Assembly(scenario.assemblyQuorum);
543
+ scenario.approverGroups.forEach((sa, isa) => {
544
+ let approverCount = sa.approvers.length;
545
+ // if quorum is 1, then every approvers in the sub assembly shares the same partial key
546
+ if (sa.quorum === 1) {
547
+ approverCount = 1;
548
+ }
549
+ slipAssembly.addSubAssembly(new slip.SubAssembly(isa, sa.quorum, approverCount));
550
+ });
551
+ yield this.slip39Service.generateShares(rawAssemblyKey, ScenarioApproverService.SLIP39_PASSPHRASE, slipAssembly);
552
+ // Copy the partial keys
553
+ yield Promise.all(scenario.approverGroups.map((sa, isa) => __awaiter(this, void 0, void 0, function* () {
554
+ const slipSubAssembly = slipAssembly.subAssemblies[isa];
555
+ const inputSubAssembly = input.approverAssembly.subAssemblies[isa];
556
+ yield Promise.all(sa.approvers.map((approver, ia) => __awaiter(this, void 0, void 0, function* () {
557
+ const sharedKey = yield this.keyGraph.getKey(approver.keyId);
558
+ // if quorum is 1, then every approvers in the sub assembly shares the same partial key
559
+ const share = sa.quorum === 1
560
+ ? slipSubAssembly.shares[0]
561
+ : slipSubAssembly.shares[ia];
562
+ const partialAssemblyKey = {
563
+ slip39: {
564
+ share,
565
+ subAssembly: {
566
+ quorum: sa.quorum,
567
+ size: sa.approvers.length,
568
+ },
569
+ },
570
+ assemblyKeyParams,
571
+ };
572
+ inputSubAssembly.approvers[ia].sharedCipherPartialAssemblyKey = yield this.keyGraph.encryptToString(sharedKey.jwk, partialAssemblyKey);
573
+ })));
574
+ })));
575
+ }
576
+ yield this.lrApollo.mutate({
577
+ mutation: ResetScenarioMutation,
578
+ variables: { input },
579
+ });
580
+ });
581
+ }
582
+ getAllScenarioIds() {
583
+ return __awaiter(this, void 0, void 0, function* () {
584
+ const { scenarios } = yield this.lrApollo.query({
585
+ query: GetAllScenarioIdsQuery,
586
+ });
587
+ return scenarios.edges.map((edge) => edge.node.id);
588
+ });
589
+ }
590
+ }
591
+ ScenarioService.ɵprov = i0.ɵɵdefineInjectable({ factory: function ScenarioService_Factory() { return new ScenarioService(i0.ɵɵinject(i1.LrApolloService), i0.ɵɵinject(i2.KeyMetaService), i0.ɵɵinject(i3.KeyFactoryService), i0.ɵɵinject(i4.KeyService), i0.ɵɵinject(i5.EncryptionService), i0.ɵɵinject(i6.KeyGraphService), i0.ɵɵinject(i7.TrustedPartyService), i0.ɵɵinject(i8.Slip39Service), i0.ɵɵinject(i9.ScenarioClaimantService), i0.ɵɵinject(i10.ScenarioApproverService), i0.ɵɵinject(i11.ScenarioReceiverService), i0.ɵɵinject(i12.LrGraphQLService)); }, token: ScenarioService, providedIn: "root" });
592
+ ScenarioService.decorators = [
593
+ { type: Injectable, args: [{
594
+ providedIn: 'root',
595
+ },] }
596
+ ];
597
+ ScenarioService.ctorParameters = () => [
598
+ { type: LrApolloService },
599
+ { type: KeyMetaService },
600
+ { type: KFS },
601
+ { type: KeyService },
602
+ { type: EncryptionService },
603
+ { type: KeyGraphService },
604
+ { type: TrustedPartyService },
605
+ { type: slip.Slip39Service },
606
+ { type: ScenarioClaimantService },
607
+ { type: ScenarioApproverService },
608
+ { type: ScenarioReceiverService },
609
+ { type: LrGraphQLService }
610
+ ];
611
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scenario.service.js","sourceRoot":"/opt/atlassian/pipelines/agent/build/projects/core/src/","sources":["lib/scenario/scenario.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { JWK } from 'node-jose';\nimport { LrApolloService } from '../api/lr-apollo.service';\nimport { CategoryFilter, RecordFilter } from '../category/category.gql';\nimport { EncryptionService } from '../cryptography/encryption.service';\nimport { KeyGraphService } from '../cryptography/key-graph.service';\nimport { KeyMetaService } from '../cryptography/key-meta.service';\nimport { KeyService } from '../cryptography/key.service';\nimport * as slip from '../cryptography/slip39.service';\nimport { RecordContentFilter } from '../record/record.gql';\nimport { TrustedPartyService } from '../trusted-parties/trusted-party.service';\nimport {\n  LrException,\n  LrErrorCode,\n  LrBadArgumentException,\n} from '../_common/exceptions';\nimport { ApprovalGroup, Approver } from './approvals/scenario-approval.types';\nimport { ScenarioApproverService } from './approvals/scenario-approver.service';\nimport { ScenarioClaimantService } from './claimants/scenario-claimant.service';\nimport { Claimant } from './claimants/scenario-claimant.types';\nimport { ScenarioReceiverService } from './receivers/scenario-receiver.service';\nimport { Receiver } from './receivers/scenario-receiver.types';\nimport {\n  ApproveScenarioClaimMutation,\n  CancelScenarioClaimMutation,\n  CreateScenarioClaimMutation,\n  CreateScenarioMutation,\n  DeleteScenarioMutation,\n  DisableScenarioMutation,\n  EnableScenarioMutation,\n  GetAllScenarioClaimsQuery,\n  GetAllScenariosQuery,\n  GetAllSharedScenariosQuery,\n  GetScenarioQuery,\n  GetSharedScenarioQuery,\n  GetTrustedPartyScenariosQuery,\n  ReceiveScenarioClaimMutation,\n  RejectScenarioClaimMutation,\n  ResetScenarioMutation,\n  UpdateScenarioMutation,\n  GetAllScenarioIdsQuery,\n} from './scenario.gql';\nimport {\n  CreateScenarioInput,\n  PartialAssemblyKey,\n  Scenario,\n  ScenarioClaim,\n  ScenarioState,\n  ScenarioSummary,\n  SharedScenario,\n  UpdateScenarioInput,\n  SharedScenarioClaimApprover,\n  ApproverClaimState,\n  SharedScenarioSummary,\n} from './scenario.types';\nimport * as moment_ from 'moment';\nimport { KeyFactoryService as KFS } from '../cryptography/key-factory.service';\nimport {\n  LrGraphQLService,\n  LrMergedMutation,\n  LrMutation,\n} from '../api/lr-graphql';\n\n// Ref: https://stackoverflow.com/questions/59735280/angular-8-moment-error-cannot-call-a-namespace-moment\nconst moment = moment_;\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class ScenarioService {\n  constructor(\n    private lrApollo: LrApolloService,\n    private keyMetaService: KeyMetaService,\n    private keyFactory: KFS,\n    private keyService: KeyService,\n    private encryptionService: EncryptionService,\n    private keyGraph: KeyGraphService,\n    private tpService: TrustedPartyService,\n    private slip39Service: slip.Slip39Service,\n    private scenarioClaimantService: ScenarioClaimantService,\n    private scenarioApproverService: ScenarioApproverService,\n    private scenarioReceiverService: ScenarioReceiverService,\n    private lrGraphQL: LrGraphQLService\n  ) {}\n\n  public async getMyScenarios(): Promise<ScenarioSummary[]> {\n    const { scenarios } = await this.lrApollo.query<any>({\n      query: GetAllScenariosQuery,\n    });\n    return await Promise.all(\n      scenarios.edges.map((x: any) => this.mapScenarioSummary(x.node))\n    );\n  }\n\n  private async mapScenarioSummary(scenario: any): Promise<ScenarioSummary> {\n    const { event, name } = await this.keyGraph.decryptFromString<{\n      event: string;\n      name: string;\n    }>(scenario.subjectKey.id, scenario.subjectCipherData);\n\n    return {\n      id: scenario.id,\n      name,\n      event,\n      status: scenario.state,\n      claimId: scenario.claim && scenario.claim.id,\n      claimStatus: scenario.claim && scenario.claim.state,\n      createdOn: scenario.created,\n      lastModified: scenario.modified,\n    };\n  }\n\n  public async getSharedScenarios(): Promise<SharedScenarioSummary[]> {\n    const { sharedScenarios } = await this.lrApollo.query<any>({\n      query: GetAllSharedScenariosQuery,\n    });\n    return (\n      await Promise.all<SharedScenario>(\n        sharedScenarios.edges.map((x: any) => this.mapSharedScenario(x.node))\n      )\n    ).filter((x) => x);\n  }\n\n  private async mapSharedScenarioSummary(\n    scenario: any\n  ): Promise<ScenarioSummary> {\n    const { event, name } = await this.keyGraph.decryptFromString<{\n      event: string;\n      name: string;\n    }>(scenario.subjectKey.id, scenario.subjectCipherData);\n\n    return {\n      id: scenario.id,\n      name,\n      event,\n      status: scenario.state,\n      claimId: scenario.claim && scenario.claim.id,\n      claimStatus: scenario.claim && scenario.claim.state,\n      createdOn: scenario.created,\n      lastModified: scenario.modified,\n    };\n  }\n\n  public async getSharedScenario(scenarioId: string): Promise<SharedScenario> {\n    const { sharedScenario } = await this.lrApollo.query<any>({\n      query: GetSharedScenarioQuery,\n      variables: {\n        id: scenarioId,\n      },\n    });\n    return await this.mapSharedScenario(sharedScenario);\n  }\n\n  private async mapSharedScenario(scenario: any): Promise<SharedScenario> {\n    try {\n      const claimantData = await this.getCipherData(scenario.asClaimant);\n      const receiverData = await this.getCipherData(scenario.asReceiver);\n      const approverData = await Promise.all<{\n        event?: string;\n        message?: string;\n      }>(\n        scenario.asApprovers.edges.map((x) =>\n          this.getCipherData(x.node.approver)\n        )\n      );\n\n      return {\n        id: scenario.id,\n        event:\n          claimantData.event ||\n          receiverData.event ||\n          approverData.map((x) => x.event)[0],\n        status: scenario.state,\n        trustedParty: await this.tpService.mapTrustedParty(scenario.tp),\n        isClaimant: !!scenario.asClaimant,\n        claimantMessage: claimantData.message,\n        isApprover: scenario.asApprovers.edges.length > 0,\n        approverMessages: approverData.map((x) => x.message),\n        isReceiver: !!scenario.asReceiver,\n        receiverMessage: receiverData.message,\n        receiverKeyId: scenario.asReceiver && scenario.asReceiver.sharedKey.id,\n        receiverPbkId: scenario.asReceiver && scenario.asReceiver.pbk.id,\n        receiverDirectories:\n          scenario.asReceiver &&\n          scenario.asReceiver.receiverDirectories.edges.map((x) => x.node),\n        claim: scenario.sharedClaim\n          ? {\n              id: scenario.sharedClaim.id,\n              isClaimant: scenario.sharedClaim.isClaimant,\n              status: scenario.sharedClaim.state,\n              asApprovers: await Promise.all<SharedScenarioClaimApprover>(\n                scenario.sharedClaim.asClaimApprovers.edges\n                  .map((x) => x.node)\n                  .map(async (x) => ({\n                    approverId: x.approver.id,\n                    approverKey: await this.getApproverKey(x.approver),\n                    status: x.state,\n                    receivers: x.receivers.edges.map((y) => ({\n                      id: y.node.id,\n                      pbkId: y.node.pbk.id,\n                    })),\n                  }))\n              ),\n              asReceiver: scenario.sharedClaim.asClaimReceiver\n                ? {\n                    received: scenario.sharedClaim.asClaimReceiver.received,\n                    ciphers: scenario.sharedClaim.asClaimReceiver.approvals.edges.map(\n                      (x) => x.node.receiverPbkCipher\n                    ),\n                  }\n                : null,\n            }\n          : null,\n      };\n    } catch (e) {\n      console.error('Failed to decrypt shared scenario.', e, scenario);\n      return null;\n    }\n  }\n\n  public async getTrustedPartyScenarios(\n    trustedPartyId: string\n  ): Promise<{\n    myScenarios: ScenarioSummary[];\n    sharedScenarios: SharedScenario[];\n  }> {\n    const { tp } = await this.lrApollo.query<any>({\n      query: GetTrustedPartyScenariosQuery,\n      variables: { partyId: trustedPartyId },\n    });\n    return {\n      myScenarios: await Promise.all(\n        tp.myScenarios.edges.map((x: any) => this.mapScenarioSummary(x.node))\n      ),\n      sharedScenarios: await Promise.all(\n        tp.sharedScenarios.edges.map((x: any) => this.mapSharedScenario(x.node))\n      ),\n    };\n  }\n\n  public async getScenarioClaims(): Promise<ScenarioClaim[]> {\n    const { scenarios } = await this.lrApollo.query<any>({\n      query: GetAllScenarioClaimsQuery,\n    });\n\n    const claims = await Promise.all<ScenarioClaim[]>(\n      scenarios.edges.map(async (x: any) => {\n        const scenario = await this.mapScenarioSummary(x.node);\n\n        return await Promise.all<ScenarioClaim>(\n          x.node.claims.edges.map(async (y) => ({\n            id: y.node.id,\n            state: y.node.state,\n            triggeredBy: await this.tpService.mapTrustedParty(\n              y.node.claimant.tp\n            ),\n            triggeredOn: y.node.created,\n            lastModified: y.node.modified,\n            scenario,\n          }))\n        );\n      })\n    );\n\n    return claims\n      .reduce((x, y) => [...x, ...y], [])\n      .sort(\n        (x, y) =>\n          -1 *\n          moment(new Date(x.lastModified)).diff(\n            moment(new Date(y.lastModified))\n          )\n      );\n  }\n\n  private async getCipherData(cipher?: {\n    sharedKey: { id: string };\n    sharedCipherData: string;\n  }): Promise<{ event?: string; message?: string }> {\n    if (!cipher) return {};\n\n    return await this.keyGraph.decryptFromString<{\n      event?: string;\n      message?: string;\n    }>(cipher.sharedKey.id, cipher.sharedCipherData);\n  }\n\n  private async getApproverKey(cipher?: {\n    sharedKey: { id: string };\n    sharedCipherPartialAssemblyKey: string;\n  }): Promise<string> {\n    if (!cipher) return null;\n\n    return await this.keyGraph.decryptFromString<string>(\n      cipher.sharedKey.id,\n      cipher.sharedCipherPartialAssemblyKey\n    );\n  }\n\n  public async getScenario(scenarioId: string): Promise<Scenario> {\n    const { scenario } = await this.lrApollo.query<any>({\n      query: GetScenarioQuery,\n      variables: {\n        id: scenarioId,\n        categoryFilter: CategoryFilter,\n        recordFilter: RecordFilter,\n        contentFilter: RecordContentFilter,\n      },\n    });\n    return await this.mapScenario(scenario);\n  }\n\n  private async mapScenario(scenario: any): Promise<Scenario> {\n    const { name, event } = await this.keyGraph.decryptFromString<{\n      event: string;\n      name: string;\n    }>(scenario.subjectKey.id, scenario.subjectCipherData);\n    const claimants = await Promise.all<Claimant>(\n      scenario.claimants.edges.map((x) =>\n        this.scenarioClaimantService.mapClaimant(x.node)\n      )\n    );\n\n    return {\n      id: scenario.id,\n      keyId: scenario.subjectKey.id,\n      assemblyKeyId:\n        scenario.approverAssembly && scenario.approverAssembly.assemblyKey.id,\n      assemblyQuorum:\n        scenario.approverAssembly && scenario.approverAssembly.quorum,\n      name,\n      event,\n      status: scenario.state,\n      claimants,\n      approverGroups: scenario.approverAssembly\n        ? await Promise.all(\n            scenario.approverAssembly.subAssemblies.edges.map((x) =>\n              this.scenarioApproverService.mapApproverGroup(x.node)\n            )\n          )\n        : [],\n      receivers: await Promise.all(\n        scenario.receivers.edges.map((x) =>\n          this.scenarioReceiverService.mapReceiver(x.node)\n        )\n      ),\n      claim: scenario.claim\n        ? {\n            id: scenario.claim.id,\n            status: scenario.claim.state,\n            claimant: claimants.find(\n              (x) => x.id === scenario.claim.claimant.id\n            ),\n          }\n        : null,\n    };\n  }\n\n  public async createScenario(input: CreateScenarioInput): Promise<string> {\n    const rootKey = await this.keyService.getCurrentRootKey();\n\n    const subjectKey = await this.keyFactory.createKey();\n    const rootKeyWrappedSubjectKey = await this.keyGraph.encryptToString(\n      rootKey.jwk,\n      subjectKey.toJSON(true)\n    );\n\n    const subjectCipherData = await this.keyGraph.encryptToString(\n      subjectKey,\n      input.plainSubjectCipherData\n    );\n\n    const { createScenario } = await this.lrApollo.mutate<any>({\n      mutation: CreateScenarioMutation,\n      variables: {\n        input: {\n          rootKeyId: rootKey.id,\n          rootKeyWrappedSubjectKey,\n          subjectCipherData,\n        },\n      },\n    });\n    return createScenario.scenario.id;\n  }\n\n  public async updateScenario(input: UpdateScenarioInput): Promise<void> {\n    await this.lrApollo.mutate<void>({\n      mutation: UpdateScenarioMutation,\n      variables: {\n        input: {\n          scenarioId: input.scenarioId,\n          subjectKeyId: input.keyId,\n          subjectCipherData: await this.keyGraph.encryptToString(\n            input.keyId,\n            input.plainSubjectCipherData\n          ),\n        },\n      },\n    });\n  }\n\n  public async enableScenario(scenarioId: string): Promise<void> {\n    await this.lrApollo.mutate<void>({\n      mutation: EnableScenarioMutation,\n      variables: { input: { scenarioId } },\n    });\n  }\n\n  public async disableScenario(scenarioId: string): Promise<void> {\n    await this.lrApollo.mutate<void>({\n      mutation: DisableScenarioMutation,\n      variables: { input: { scenarioId } },\n    });\n  }\n\n  public async deleteScenario(scenarioId: string): Promise<void> {\n    await this.lrApollo.mutate<void>({\n      mutation: DeleteScenarioMutation,\n      variables: { input: { scenarioId } },\n    });\n  }\n\n  public async createClaim(scenarioId: string): Promise<string> {\n    const res = await this.lrApollo.mutate<any>({\n      mutation: CreateScenarioClaimMutation,\n      variables: { input: { scenarioId } },\n    });\n    return res.createScenarioClaim.sharedClaim.id;\n  }\n\n  public async cancelClaim(claimId: string): Promise<void> {\n    await this.lrApollo.mutate<void>({\n      mutation: CancelScenarioClaimMutation,\n      variables: { input: { claimId } },\n    });\n  }\n\n  public async approveClaim(scenarioId: string, claimId: string) {\n    return this.lrGraphQL.lrMutate(\n      this.approveClaimMutation(scenarioId, claimId)\n    );\n  }\n\n  public async approveClaimMutation(scenarioId: string, claimId: string) {\n    const sharedScenario = await this.getSharedScenario(scenarioId);\n\n    // Double check the claim matches\n    if (sharedScenario.claim.id !== claimId) {\n      throw new LrException({\n        code: LrErrorCode.ReceiveClaimMismatch,\n        message:\n          'claimId does not match with the current claimId of the scenario',\n      });\n    }\n\n    const createMutation = async (asApprover: SharedScenarioClaimApprover) => {\n      return new LrMutation({\n        mutation: ApproveScenarioClaimMutation,\n        variables: {\n          input: {\n            claimId,\n            approverId: asApprover.approverId,\n            receivers: await Promise.all(\n              asApprover.receivers.map(async (y) => ({\n                receiverId: y.id,\n                receiverPbkCipher: await this.keyGraph.encryptToString(\n                  y.pbkId,\n                  { partialAssemblyKey: asApprover.approverKey }\n                ),\n              }))\n            ),\n          },\n        },\n      });\n    };\n\n    const mutations = sharedScenario.claim.asApprovers\n      .filter((asApprover) => asApprover.status === ApproverClaimState.Claimed)\n      .map((asApprover) => createMutation(asApprover));\n\n    return LrMergedMutation.create(await Promise.all(mutations));\n  }\n\n  public async rejectClaim(scenarioId: string, claimId: string) {\n    return this.lrGraphQL.lrMutate(\n      this.rejectClaimMutation(scenarioId, claimId)\n    );\n  }\n\n  public async rejectClaimMutation(scenarioId: string, claimId: string) {\n    const sharedScenario = await this.getSharedScenario(scenarioId);\n\n    // Double check the claim matches\n    if (sharedScenario.claim.id !== claimId) {\n      throw new LrException({\n        code: LrErrorCode.ReceiveClaimMismatch,\n        message:\n          'ClaimId does not match with the current claimId of the scenario',\n      });\n    }\n\n    const createMutation = async (asApprover: SharedScenarioClaimApprover) => {\n      return new LrMutation({\n        mutation: RejectScenarioClaimMutation,\n        variables: { input: { claimId, approverId: asApprover.approverId } },\n      });\n    };\n\n    const mutations = sharedScenario.claim.asApprovers\n      .filter((asApprover) => asApprover.status === ApproverClaimState.Claimed)\n      .map((asApprover) => createMutation(asApprover));\n\n    return LrMergedMutation.create(await Promise.all(mutations));\n  }\n\n  public async receiveClaim(\n    scenarioId: string,\n    claimId: string\n  ): Promise<void> {\n    // Get all the shared items\n    const sharedScenario = await this.getSharedScenario(scenarioId);\n\n    // Double check the claim matches\n    if (sharedScenario.claim.id !== claimId) {\n      throw new LrException({\n        code: LrErrorCode.ReceiveClaimMismatch,\n        message:\n          'ClaimId does not match with the current claimId of the scenario',\n      });\n    }\n    if (sharedScenario.status !== ScenarioState.APPROVED) {\n      throw new LrException({\n        code: LrErrorCode.BadState,\n        message: 'Scenario claim has not been approved',\n      });\n    }\n\n    const assemblyKey = await this.getClaimAssemblyKey(\n      sharedScenario.receiverPbkId,\n      sharedScenario.claim.asReceiver.ciphers\n    );\n\n    // Decrypt all items\n    const receiverDirectories = await Promise.all(\n      sharedScenario.receiverDirectories.map(async (x) => {\n        const wrappedItemKey = assemblyKey\n          ? await this.encryptionService.decrypt(assemblyKey, x.wrappedItemKey)\n          : x.wrappedItemKey;\n\n        return {\n          receiverDirectoryId: x.id,\n          receiverSharedKeyWrappedItemKey: wrappedItemKey, // the wrappedItemKey is already wrapped by receiverSharedKey\n        };\n      })\n    );\n\n    await this.lrApollo.mutate<void>({\n      mutation: ReceiveScenarioClaimMutation,\n      variables: {\n        input: {\n          claimId,\n          receiverDirectories,\n        },\n      },\n    });\n  }\n\n  private async getClaimAssemblyKey(keyId: string, ciphers: string[]) {\n    if (!ciphers || !ciphers.length) return null;\n\n    let assemblyKeyParams: object;\n\n    const shares = await Promise.all(\n      ciphers.map(async (x) => {\n        const { partialAssemblyKey } = await this.keyGraph.decryptFromString<{\n          partialAssemblyKey: PartialAssemblyKey;\n        }>(keyId, x);\n\n        if (assemblyKeyParams) {\n          if (\n            JSON.stringify(assemblyKeyParams) !==\n            JSON.stringify(partialAssemblyKey.assemblyKeyParams)\n          ) {\n            throw new LrException({\n              code: LrErrorCode.BadState,\n              message:\n                'The assembly key parameters are different between the approvals.',\n            });\n          }\n        } else {\n          assemblyKeyParams = partialAssemblyKey.assemblyKeyParams;\n        }\n        return partialAssemblyKey.slip39.share.mnemonics;\n      })\n    );\n\n    const rawAssemblyKey = await this.slip39Service.recoverSecret(\n      shares,\n      ScenarioApproverService.SLIP39_PASSPHRASE\n    );\n\n    return await KFS.asKey({\n      ...assemblyKeyParams,\n      k: rawAssemblyKey,\n    });\n  }\n\n  public async resetScenario(\n    scenarioId: string,\n    disable: boolean = false\n  ): Promise<void> {\n    const prepareReceiverItem = async (\n      itemKeyId: string,\n      sharedKeyId: string,\n      assemblyKey: JWK.Key\n    ): Promise<string> => {\n      const sharedKey = await this.keyGraph.getKey(sharedKeyId);\n      const itemKey = await this.keyGraph.getKey(itemKeyId);\n\n      let wrappedItemKey = await this.keyGraph.encryptToString(\n        sharedKey.jwk,\n        itemKey.jwk.toJSON(true)\n      );\n      if (assemblyKey) {\n        wrappedItemKey = await this.keyGraph.encryptToString(\n          assemblyKey,\n          wrappedItemKey\n        );\n      }\n      return wrappedItemKey;\n    };\n\n    const prepareReceiverDirectories = async (\n      receiver: Receiver,\n      assemblyKey: JWK.Key\n    ) => {\n      return Promise.all([\n        ...receiver.categories.map(async (receiverDirectory) => ({\n          receiverDirectoryId: receiverDirectory.id,\n          wrappedItemKey: await prepareReceiverItem(\n            receiverDirectory.category.keyId,\n            receiver.keyId,\n            assemblyKey\n          ),\n        })),\n        ...receiver.records.map(async (receiverDirectory) => ({\n          receiverDirectoryId: receiverDirectory.id,\n          wrappedItemKey: await prepareReceiverItem(\n            receiverDirectory.record.keyId,\n            receiver.keyId,\n            assemblyKey\n          ),\n        })),\n      ]);\n    };\n\n    const prepareReceivers = async (\n      receivers: Receiver[],\n      assemblyKey: JWK.Key\n    ) => {\n      return Promise.all(\n        receivers.map(async (receiver) => ({\n          receiverId: receiver.id,\n          receiverDirectories: await prepareReceiverDirectories(\n            receiver,\n            assemblyKey\n          ),\n          receiverFiles: [],\n        }))\n      );\n    };\n\n    const prepareApprovers = async (approvers: Approver[]) => {\n      return Promise.all(\n        approvers.map(async (approver) => ({\n          approverId: approver.id,\n          sharedKeyId: approver.keyId,\n        }))\n      );\n    };\n\n    const prepareSubAssemblies = async (\n      subAssemblies: ApprovalGroup[],\n      assemblyKey: JWK.Key\n    ) => {\n      return Promise.all(\n        subAssemblies.map(async (sa) => ({\n          subAssemblyId: sa.id,\n          subAssemblyCipherData: await this.keyGraph.encryptToString(\n            assemblyKey,\n            { name: sa.name }\n          ),\n          approvers: await prepareApprovers(sa.approvers),\n        }))\n      );\n    };\n\n    // ------------------------------------------------------------------------------\n    // ------------------------------------------------------------------------------\n    // ------------------------------------------------------------------------------\n\n    const scenario = await this.getScenario(scenarioId);\n    if (scenario.status !== ScenarioState.APPROVED) {\n      throw new LrException({\n        code: LrErrorCode.BadState,\n        message: `Scenario must be in ${ScenarioState.APPROVED} state`,\n      });\n    }\n\n    const subjectKey = await this.keyGraph.getKey(scenario.keyId);\n    const newAssemblyKey = await this.keyFactory.createKey();\n\n    const input: any = {\n      scenarioId: scenario.id,\n      disable,\n      receivers: await prepareReceivers(scenario.receivers, newAssemblyKey),\n    };\n\n    // Approver assembly\n    const subjectKeyWrappedAssemblyKey = await this.keyGraph.encryptToString(\n      subjectKey.jwk,\n      newAssemblyKey.toJSON(true)\n    );\n\n    input.approverAssembly = {\n      subjectKeyId: subjectKey.id,\n      subjectKeyWrappedAssemblyKey,\n      assemblyCipherData: '',\n      subAssemblies: await prepareSubAssemblies(\n        scenario.approverGroups,\n        newAssemblyKey\n      ),\n    };\n\n    if (scenario.approverGroups.length) {\n      const { k: rawAssemblyKey, ...assemblyKeyParams } = newAssemblyKey.toJSON(\n        true\n      ) as any;\n\n      // Split the keys. If the scenario has been approved and there is an assembly setup, then\n      // that assembly already enough members to meet quorum to approve the claim. So we can assume\n      // that we can always do a key split here.\n      const slipAssembly = new slip.Assembly(scenario.assemblyQuorum);\n\n      scenario.approverGroups.forEach((sa, isa) => {\n        let approverCount = sa.approvers.length;\n        // if quorum is 1, then every approvers in the sub assembly shares the same partial key\n        if (sa.quorum === 1) {\n          approverCount = 1;\n        }\n        slipAssembly.addSubAssembly(\n          new slip.SubAssembly(isa, sa.quorum, approverCount)\n        );\n      });\n\n      await this.slip39Service.generateShares(\n        rawAssemblyKey,\n        ScenarioApproverService.SLIP39_PASSPHRASE,\n        slipAssembly\n      );\n\n      // Copy the partial keys\n      await Promise.all(\n        scenario.approverGroups.map(async (sa, isa) => {\n          const slipSubAssembly = slipAssembly.subAssemblies[isa];\n          const inputSubAssembly = input.approverAssembly.subAssemblies[isa];\n\n          await Promise.all(\n            sa.approvers.map(async (approver, ia) => {\n              const sharedKey = await this.keyGraph.getKey(approver.keyId);\n\n              // if quorum is 1, then every approvers in the sub assembly shares the same partial key\n              const share =\n                sa.quorum === 1\n                  ? slipSubAssembly.shares[0]\n                  : slipSubAssembly.shares[ia];\n\n              const partialAssemblyKey: PartialAssemblyKey = {\n                slip39: {\n                  share,\n                  subAssembly: {\n                    quorum: sa.quorum,\n                    size: sa.approvers.length,\n                  },\n                },\n                assemblyKeyParams,\n              };\n              inputSubAssembly.approvers[\n                ia\n              ].sharedCipherPartialAssemblyKey = await this.keyGraph.encryptToString(\n                sharedKey.jwk,\n                partialAssemblyKey\n              );\n            })\n          );\n        })\n      );\n    }\n    await this.lrApollo.mutate<any>({\n      mutation: ResetScenarioMutation,\n      variables: { input },\n    });\n  }\n\n  public async getAllScenarioIds(): Promise<string[]> {\n    const { scenarios } = await this.lrApollo.query<any>({\n      query: GetAllScenarioIdsQuery,\n    });\n    return scenarios.edges.map((edge) => edge.node.id);\n  }\n}\n"]}