@lifeready/core 1.0.2 → 1.0.3

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,300 +1,300 @@
1
- import { __awaiter, __rest } from "tslib";
2
- import { Injectable } from '@angular/core';
3
- import { LrApolloService } from '../../api/lr-apollo.service';
4
- import { EncryptionService } from '../../cryptography/encryption.service';
5
- import { KeyFactoryService } from '../../cryptography/key-factory.service';
6
- import { KeyGraphService } from '../../cryptography/key-graph.service';
7
- import { KeyMetaService } from '../../cryptography/key-meta.service';
8
- import * as slip from '../../cryptography/slip39.service';
9
- import { TrustedPartyService } from '../../trusted-parties/trusted-party.service';
10
- import { CreateScenarioApproverAssemblyMutation, DeleteScenarioApproverAssemblyMutation, GetScenarioApproverQuery, UpdateScenarioApproverAssemblyMutation, UpdateScenarioApproverMutation, } from './scenario-approval.gql';
11
- import * as i0 from "@angular/core";
12
- import * as i1 from "../../api/lr-apollo.service";
13
- import * as i2 from "../../cryptography/key-factory.service";
14
- import * as i3 from "../../cryptography/key-meta.service";
15
- import * as i4 from "../../cryptography/key-graph.service";
16
- import * as i5 from "../../cryptography/slip39.service";
17
- import * as i6 from "../../cryptography/encryption.service";
18
- import * as i7 from "../../trusted-parties/trusted-party.service";
19
- export class ScenarioApproverService {
20
- constructor(lrApollo, keyFactory, keyMetaService, keyGraph, slip39Service, encryptionService, trustedPartyService) {
21
- this.lrApollo = lrApollo;
22
- this.keyFactory = keyFactory;
23
- this.keyMetaService = keyMetaService;
24
- this.keyGraph = keyGraph;
25
- this.slip39Service = slip39Service;
26
- this.encryptionService = encryptionService;
27
- this.trustedPartyService = trustedPartyService;
28
- }
29
- getApprover(approverId) {
30
- return __awaiter(this, void 0, void 0, function* () {
31
- const { scenarioApprover } = yield this.lrApollo.query({
32
- query: GetScenarioApproverQuery,
33
- variables: {
34
- id: approverId,
35
- },
36
- });
37
- return this.mapApprover(scenarioApprover);
38
- });
39
- }
40
- mapApproverGroup(group) {
41
- return __awaiter(this, void 0, void 0, function* () {
42
- const { name } = yield this.keyGraph.decryptFromString(group.assemblyKey.id, group.subAssemblyCipherData);
43
- return {
44
- id: group.id,
45
- keyId: group.assemblyKey.id,
46
- name,
47
- quorum: group.quorum,
48
- singleReject: group.singleReject,
49
- approvers: yield Promise.all(group.approvers.edges.map((x) => this.mapApprover(x.node))),
50
- };
51
- });
52
- }
53
- mapApprover(approver) {
54
- return __awaiter(this, void 0, void 0, function* () {
55
- const { message } = yield this.keyGraph.decryptFromString(approver.sharedKey.id, approver.sharedCipherData);
56
- return {
57
- id: approver.id,
58
- keyId: approver.sharedKey.id,
59
- trustedParty: yield this.trustedPartyService.mapTrustedParty(approver.tp),
60
- message,
61
- };
62
- });
63
- }
64
- updateApprover(approver) {
65
- return __awaiter(this, void 0, void 0, function* () {
66
- const sharedCipherData = yield this.keyGraph.encryptToString(approver.keyId, approver.plainSharedCipherData);
67
- yield this.lrApollo.mutate({
68
- mutation: UpdateScenarioApproverMutation,
69
- variables: {
70
- input: {
71
- approverId: approver.approverId,
72
- sharedKeyId: approver.keyId,
73
- sharedCipherData,
74
- sharedCipherApprovalData: '',
75
- },
76
- },
77
- });
78
- });
79
- }
80
- createScenarioApproverAssembly(input) {
81
- return __awaiter(this, void 0, void 0, function* () {
82
- const assemblyKey = yield this.keyFactory.createKey();
83
- const subjectKeyWrappedAssemblyKey = yield this.keyGraph.encryptToString(input.keyId, assemblyKey.toJSON(true));
84
- const assemblyCipherData = input.plainAssemblyCipherData
85
- ? yield this.keyGraph.encryptToString(assemblyKey, input.plainAssemblyCipherData)
86
- : '';
87
- const { createScenarioApproverAssembly } = yield this.lrApollo.mutate({
88
- mutation: CreateScenarioApproverAssemblyMutation,
89
- variables: {
90
- input: {
91
- scenarioId: input.scenarioId,
92
- singleReject: input.singleReject,
93
- quorum: input.quorum,
94
- subjectKeyId: input.keyId,
95
- subjectKeyWrappedAssemblyKey,
96
- assemblyCipherData,
97
- createSubAssemblies: (yield this.mapApprovalGroups(input.approvalGroups, input.quorum, assemblyKey)).map((x) => {
98
- const { updateApprovers, deleteApprovers } = x, subAssembly = __rest(x, ["updateApprovers", "deleteApprovers"]);
99
- return subAssembly;
100
- }),
101
- updateReceivers: yield this.rewrapReceivers(assemblyKey, input.event, input.receivers),
102
- },
103
- },
104
- });
105
- return createScenarioApproverAssembly.scenario.approverAssembly.assemblyKey
106
- .id;
107
- });
108
- }
109
- updateScenarioApproverAssembly(input) {
110
- return __awaiter(this, void 0, void 0, function* () {
111
- const assemblyKey = yield this.keyGraph.getKey(input.assemblyKeyId);
112
- const assemblyCipherData = input.plainAssemblyCipherData
113
- ? yield this.keyGraph.encryptToString(assemblyKey.jwk, input.plainAssemblyCipherData)
114
- : '';
115
- const approvalGroups = yield this.mapApprovalGroups(input.approvalGroups, input.quorum, assemblyKey.jwk);
116
- yield this.lrApollo.mutate({
117
- mutation: UpdateScenarioApproverAssemblyMutation,
118
- variables: {
119
- input: {
120
- scenarioId: input.scenarioId,
121
- singleReject: input.singleReject,
122
- quorum: input.quorum,
123
- assemblyKeyId: assemblyKey.id,
124
- assemblyCipherData,
125
- createSubAssemblies: approvalGroups
126
- .filter((x) => !x.subAssemblyId)
127
- .map((x) => {
128
- const { updateApprovers, deleteApprovers } = x, subAssembly = __rest(x, ["updateApprovers", "deleteApprovers"]);
129
- return subAssembly;
130
- }),
131
- updateSubAssemblies: approvalGroups.filter((x) => x.subAssemblyId),
132
- deleteSubAssemblies: input.deletedGroupIds,
133
- },
134
- },
135
- });
136
- });
137
- }
138
- deleteScenarioApproverAssembly(scenarioId, event, receivers) {
139
- return __awaiter(this, void 0, void 0, function* () {
140
- yield this.lrApollo.mutate({
141
- mutation: DeleteScenarioApproverAssemblyMutation,
142
- variables: {
143
- input: {
144
- scenarioId,
145
- updateReceivers: yield this.rewrapReceivers(null, event, receivers),
146
- },
147
- },
148
- });
149
- });
150
- }
151
- rewrapReceivers(assemblyKey, event, receivers) {
152
- return __awaiter(this, void 0, void 0, function* () {
153
- if (!receivers || !receivers.length) {
154
- return [];
155
- }
156
- return yield Promise.all(receivers.map((receiver) => __awaiter(this, void 0, void 0, function* () {
157
- const sharedKey = yield this.keyGraph.getKey(receiver.keyId);
158
- const prepareReceiverItem = (item, itemKeyId) => __awaiter(this, void 0, void 0, function* () {
159
- const itemKey = yield this.keyGraph.getKey(itemKeyId);
160
- let wrappedItemKey = yield this.keyGraph.encryptToString(sharedKey.jwk, itemKey.jwk.toJSON(true));
161
- if (assemblyKey) {
162
- wrappedItemKey = yield this.keyGraph.encryptToString(assemblyKey, wrappedItemKey);
163
- }
164
- return {
165
- accessRole: item.accessLevel,
166
- sharedKeyId: sharedKey.id,
167
- sharedCipherData: '',
168
- wrappedItemKey,
169
- };
170
- });
171
- // For each receiver-directory
172
- const receiverDirectories = yield Promise.all([
173
- ...receiver.categories.map((x) => __awaiter(this, void 0, void 0, function* () {
174
- return (Object.assign(Object.assign({}, (yield prepareReceiverItem(x, x.category.keyId))), { receiverDirectoryId: x.id }));
175
- })),
176
- ...receiver.records.map((x) => __awaiter(this, void 0, void 0, function* () {
177
- return (Object.assign(Object.assign({}, (yield prepareReceiverItem(x, x.record.keyId))), { receiverDirectoryId: x.id }));
178
- })),
179
- ]);
180
- return {
181
- receiverId: receiver.id,
182
- sharedKeyId: receiver.keyId,
183
- receiverDirectories,
184
- receiverFiles: [],
185
- sharedCipherData: yield this.keyGraph.encryptToString(sharedKey.jwk, {
186
- event,
187
- message: receiver.message,
188
- }),
189
- };
190
- })));
191
- });
192
- }
193
- mapApprovalGroups(approvalGroups, quorum, assemblyKey) {
194
- return __awaiter(this, void 0, void 0, function* () {
195
- const slipAssembly = yield this.createSlipAssembly(quorum, approvalGroups, assemblyKey.toJSON(true).k);
196
- return yield Promise.all(approvalGroups.map((x, index) => this.mapApprovalGroup(x, slipAssembly.subAssemblies[index], assemblyKey)));
197
- });
198
- }
199
- mapApprovalGroup(approvalGroup, subAssembly, assemblyKey) {
200
- return __awaiter(this, void 0, void 0, function* () {
201
- const approvers = yield this.mapApprovers(approvalGroup.approvers, approvalGroup.quorum, subAssembly, assemblyKey);
202
- return {
203
- subAssemblyId: approvalGroup.subAssemblyId,
204
- singleReject: approvalGroup.singleReject,
205
- quorum: approvalGroup.quorum,
206
- subAssemblyCipherData: yield this.keyGraph.encryptToString(assemblyKey, approvalGroup.plainSubAssemblyCipherData),
207
- createApprovers: approvers.filter((x) => !x.approverId),
208
- updateApprovers: approvers.filter((x) => x.approverId),
209
- deleteApprovers: approvalGroup.deletedApproverIds || [],
210
- };
211
- });
212
- }
213
- mapApprovers(approvers, quorum, subAssembly, assemblyKey) {
214
- return __awaiter(this, void 0, void 0, function* () {
215
- const _a = assemblyKey.toJSON(true), { k: rawAssemblyKey } = _a, assemblyKeyParams = __rest(_a, ["k"]);
216
- let shareIdx = 0;
217
- const nextPartialAssemblyKey = (sharedKeyJwk) => __awaiter(this, void 0, void 0, function* () {
218
- const share = subAssembly.shares[shareIdx];
219
- // If quorum is 1, then using the same share for every member.
220
- if (quorum !== 1) {
221
- ++shareIdx;
222
- }
223
- const partialAssemblyKey = {
224
- slip39: {
225
- share,
226
- subAssembly: {
227
- quorum,
228
- size: approvers.length,
229
- },
230
- },
231
- assemblyKeyParams,
232
- };
233
- return this.keyGraph.encryptToString(sharedKeyJwk, partialAssemblyKey);
234
- });
235
- return yield Promise.all(approvers.map((x) => __awaiter(this, void 0, void 0, function* () {
236
- if (x.approverId) {
237
- const sharedKey = yield this.keyGraph.getKey(x.keyId);
238
- const sharedCipherData = yield this.keyGraph.encryptToString(x.keyId, x.plainSharedCipherData);
239
- const sharedCipherApprovalData = yield this.keyGraph.encryptToString(x.keyId, x.approvalData);
240
- return {
241
- approverId: x.approverId,
242
- sharedKeyId: x.keyId,
243
- sharedCipherData: sharedCipherData || '',
244
- sharedCipherApprovalData: sharedCipherApprovalData || '',
245
- sharedCipherPartialAssemblyKey: yield nextPartialAssemblyKey(sharedKey.jwk),
246
- };
247
- }
248
- else {
249
- const wrappedContent = yield this.keyMetaService.wrapContentWithKey(x.plainSharedCipherData, x.trustedPartySharedKeyId);
250
- return {
251
- tpId: x.trustedPartyId,
252
- tpSharedKeyId: x.trustedPartySharedKeyId,
253
- tpSharedKeyWrappedSharedKey: wrappedContent.rootKey.wrappedKey,
254
- sharedCipherData: wrappedContent.cipherMeta,
255
- sharedCipherApprovalData: '',
256
- sharedCipherPartialAssemblyKey: yield nextPartialAssemblyKey(wrappedContent.key),
257
- };
258
- }
259
- })));
260
- });
261
- }
262
- // Split assembly key between all existing approvers.
263
- createSlipAssembly(quorum, approvalGroups, rawAssemblyKey) {
264
- return __awaiter(this, void 0, void 0, function* () {
265
- const slipAssembly = new slip.Assembly(quorum);
266
- approvalGroups.forEach((x, index) => {
267
- let approverCount = x.approvers.length;
268
- // slip39 restricts quorum == 1 to have only 1 member. So we just share the same
269
- // partial key for all sub assembly members.
270
- if (x.quorum === 1) {
271
- approverCount = 1;
272
- }
273
- slipAssembly.addSubAssembly(new slip.SubAssembly(index, x.quorum, approverCount));
274
- });
275
- // Is there enough sub assemblies to meet quorum
276
- if (slipAssembly.subAssemblies.length < quorum) {
277
- return null;
278
- }
279
- yield this.slip39Service.generateShares(rawAssemblyKey, ScenarioApproverService.SLIP39_PASSPHRASE, slipAssembly);
280
- return slipAssembly;
281
- });
282
- }
283
- }
284
- ScenarioApproverService.SLIP39_PASSPHRASE = 'lifeready';
285
- ScenarioApproverService.ɵprov = i0.ɵɵdefineInjectable({ factory: function ScenarioApproverService_Factory() { return new ScenarioApproverService(i0.ɵɵinject(i1.LrApolloService), i0.ɵɵinject(i2.KeyFactoryService), i0.ɵɵinject(i3.KeyMetaService), i0.ɵɵinject(i4.KeyGraphService), i0.ɵɵinject(i5.Slip39Service), i0.ɵɵinject(i6.EncryptionService), i0.ɵɵinject(i7.TrustedPartyService)); }, token: ScenarioApproverService, providedIn: "root" });
286
- ScenarioApproverService.decorators = [
287
- { type: Injectable, args: [{
288
- providedIn: 'root',
289
- },] }
290
- ];
291
- ScenarioApproverService.ctorParameters = () => [
292
- { type: LrApolloService },
293
- { type: KeyFactoryService },
294
- { type: KeyMetaService },
295
- { type: KeyGraphService },
296
- { type: slip.Slip39Service },
297
- { type: EncryptionService },
298
- { type: TrustedPartyService }
299
- ];
300
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scenario-approver.service.js","sourceRoot":"/opt/atlassian/pipelines/agent/build/projects/core/src/","sources":["lib/scenario/approvals/scenario-approver.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 { EncryptionService } from '../../cryptography/encryption.service';\nimport { KeyFactoryService } from '../../cryptography/key-factory.service';\nimport { KeyGraphService } from '../../cryptography/key-graph.service';\nimport { KeyMetaService } from '../../cryptography/key-meta.service';\nimport * as slip from '../../cryptography/slip39.service';\nimport { TrustedPartyService } from '../../trusted-parties/trusted-party.service';\nimport {\n  Receiver,\n  ReceiverCategory,\n  ReceiverRecord,\n} from '../receivers/scenario-receiver.types';\nimport { PartialAssemblyKey } from '../scenario.types';\nimport {\n  CreateScenarioApproverAssemblyMutation,\n  DeleteScenarioApproverAssemblyMutation,\n  GetScenarioApproverQuery,\n  UpdateScenarioApproverAssemblyMutation,\n  UpdateScenarioApproverMutation,\n} from './scenario-approval.gql';\nimport {\n  ApprovalGroup,\n  Approver,\n  CreateScenarioApprovalGroups,\n  UpdateScenarioApprovalGroup,\n  UpdateScenarioApprovalGroups,\n  UpdateScenarioApprover,\n} from './scenario-approval.types';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class ScenarioApproverService {\n  public static SLIP39_PASSPHRASE = 'lifeready';\n\n  constructor(\n    private lrApollo: LrApolloService,\n    private keyFactory: KeyFactoryService,\n    private keyMetaService: KeyMetaService,\n    private keyGraph: KeyGraphService,\n    private slip39Service: slip.Slip39Service,\n    private encryptionService: EncryptionService,\n    private trustedPartyService: TrustedPartyService\n  ) {}\n\n  public async getApprover(approverId: string): Promise<Approver> {\n    const { scenarioApprover } = await this.lrApollo.query<any>({\n      query: GetScenarioApproverQuery,\n      variables: {\n        id: approverId,\n      },\n    });\n    return this.mapApprover(scenarioApprover);\n  }\n\n  public async mapApproverGroup(group: any): Promise<ApprovalGroup> {\n    const { name } = await this.keyGraph.decryptFromString<{\n      name: string;\n    }>(group.assemblyKey.id, group.subAssemblyCipherData);\n\n    return {\n      id: group.id,\n      keyId: group.assemblyKey.id,\n      name,\n      quorum: group.quorum,\n      singleReject: group.singleReject,\n      approvers: await Promise.all(\n        group.approvers.edges.map((x) => this.mapApprover(x.node))\n      ),\n    };\n  }\n\n  private async mapApprover(approver: any): Promise<Approver> {\n    const { message } = await this.keyGraph.decryptFromString<{\n      message: string;\n    }>(approver.sharedKey.id, approver.sharedCipherData);\n\n    return {\n      id: approver.id,\n      keyId: approver.sharedKey.id,\n      trustedParty: await this.trustedPartyService.mapTrustedParty(approver.tp),\n      message,\n    };\n  }\n\n  public async updateApprover(approver: UpdateScenarioApprover): Promise<void> {\n    const sharedCipherData = await this.keyGraph.encryptToString(\n      approver.keyId,\n      approver.plainSharedCipherData\n    );\n\n    await this.lrApollo.mutate<any>({\n      mutation: UpdateScenarioApproverMutation,\n      variables: {\n        input: {\n          approverId: approver.approverId,\n          sharedKeyId: approver.keyId,\n          sharedCipherData,\n          sharedCipherApprovalData: '',\n        },\n      },\n    });\n  }\n\n  public async createScenarioApproverAssembly(\n    input: CreateScenarioApprovalGroups\n  ): Promise<string> {\n    const assemblyKey = await this.keyFactory.createKey();\n\n    const subjectKeyWrappedAssemblyKey = await this.keyGraph.encryptToString(\n      input.keyId,\n      assemblyKey.toJSON(true)\n    );\n\n    const assemblyCipherData = input.plainAssemblyCipherData\n      ? await this.keyGraph.encryptToString(\n          assemblyKey,\n          input.plainAssemblyCipherData\n        )\n      : '';\n\n    const { createScenarioApproverAssembly } = await this.lrApollo.mutate<any>({\n      mutation: CreateScenarioApproverAssemblyMutation,\n      variables: {\n        input: {\n          scenarioId: input.scenarioId,\n          singleReject: input.singleReject,\n          quorum: input.quorum,\n          subjectKeyId: input.keyId,\n          subjectKeyWrappedAssemblyKey,\n          assemblyCipherData,\n          createSubAssemblies: (\n            await this.mapApprovalGroups(\n              input.approvalGroups,\n              input.quorum,\n              assemblyKey\n            )\n          ).map((x) => {\n            const { updateApprovers, deleteApprovers, ...subAssembly } = x;\n            return subAssembly;\n          }),\n          updateReceivers: await this.rewrapReceivers(\n            assemblyKey,\n            input.event,\n            input.receivers\n          ),\n        },\n      },\n    });\n    return createScenarioApproverAssembly.scenario.approverAssembly.assemblyKey\n      .id;\n  }\n\n  public async updateScenarioApproverAssembly(\n    input: UpdateScenarioApprovalGroups\n  ): Promise<void> {\n    const assemblyKey = await this.keyGraph.getKey(input.assemblyKeyId);\n    const assemblyCipherData = input.plainAssemblyCipherData\n      ? await this.keyGraph.encryptToString(\n          assemblyKey.jwk,\n          input.plainAssemblyCipherData\n        )\n      : '';\n\n    const approvalGroups = await this.mapApprovalGroups(\n      input.approvalGroups,\n      input.quorum,\n      assemblyKey.jwk\n    );\n\n    await this.lrApollo.mutate<any>({\n      mutation: UpdateScenarioApproverAssemblyMutation,\n      variables: {\n        input: {\n          scenarioId: input.scenarioId,\n          singleReject: input.singleReject,\n          quorum: input.quorum,\n          assemblyKeyId: assemblyKey.id,\n          assemblyCipherData,\n          createSubAssemblies: approvalGroups\n            .filter((x) => !x.subAssemblyId)\n            .map((x) => {\n              const { updateApprovers, deleteApprovers, ...subAssembly } = x;\n              return subAssembly;\n            }),\n          updateSubAssemblies: approvalGroups.filter((x) => x.subAssemblyId),\n          deleteSubAssemblies: input.deletedGroupIds,\n        },\n      },\n    });\n  }\n\n  public async deleteScenarioApproverAssembly(\n    scenarioId: string,\n    event: string,\n    receivers: Receiver[]\n  ): Promise<void> {\n    await this.lrApollo.mutate<any>({\n      mutation: DeleteScenarioApproverAssemblyMutation,\n      variables: {\n        input: {\n          scenarioId,\n          updateReceivers: await this.rewrapReceivers(null, event, receivers),\n        },\n      },\n    });\n  }\n\n  private async rewrapReceivers(\n    assemblyKey: JWK.Key,\n    event: string,\n    receivers: Receiver[]\n  ) {\n    if (!receivers || !receivers.length) {\n      return [];\n    }\n\n    return await Promise.all(\n      receivers.map(async (receiver) => {\n        const sharedKey = await this.keyGraph.getKey(receiver.keyId);\n\n        const prepareReceiverItem = async (\n          item: ReceiverCategory | ReceiverRecord,\n          itemKeyId: string\n        ) => {\n          const itemKey = await this.keyGraph.getKey(itemKeyId);\n          let wrappedItemKey = await this.keyGraph.encryptToString(\n            sharedKey.jwk,\n            itemKey.jwk.toJSON(true)\n          );\n\n          if (assemblyKey) {\n            wrappedItemKey = await this.keyGraph.encryptToString(\n              assemblyKey,\n              wrappedItemKey\n            );\n          }\n\n          return {\n            accessRole: item.accessLevel,\n            sharedKeyId: sharedKey.id,\n            sharedCipherData: '',\n            wrappedItemKey,\n          };\n        };\n\n        // For each receiver-directory\n        const receiverDirectories = await Promise.all([\n          ...receiver.categories.map(async (x) => ({\n            ...(await prepareReceiverItem(x, x.category.keyId)),\n            receiverDirectoryId: x.id,\n          })),\n          ...receiver.records.map(async (x) => ({\n            ...(await prepareReceiverItem(x, x.record.keyId)),\n            receiverDirectoryId: x.id,\n          })),\n        ]);\n\n        return {\n          receiverId: receiver.id,\n          sharedKeyId: receiver.keyId,\n          receiverDirectories,\n          receiverFiles: [],\n          sharedCipherData: await this.keyGraph.encryptToString(sharedKey.jwk, {\n            event,\n            message: receiver.message,\n          }),\n        };\n      })\n    );\n  }\n\n  private async mapApprovalGroups(\n    approvalGroups: UpdateScenarioApprovalGroup[],\n    quorum: number,\n    assemblyKey: JWK.Key\n  ) {\n    const slipAssembly = await this.createSlipAssembly(\n      quorum,\n      approvalGroups,\n      (assemblyKey.toJSON(true) as any).k\n    );\n    return await Promise.all(\n      approvalGroups.map((x, index) =>\n        this.mapApprovalGroup(x, slipAssembly.subAssemblies[index], assemblyKey)\n      )\n    );\n  }\n\n  private async mapApprovalGroup(\n    approvalGroup: UpdateScenarioApprovalGroup,\n    subAssembly: slip.SubAssembly,\n    assemblyKey: JWK.Key\n  ) {\n    const approvers = await this.mapApprovers(\n      approvalGroup.approvers,\n      approvalGroup.quorum,\n      subAssembly,\n      assemblyKey\n    );\n\n    return {\n      subAssemblyId: approvalGroup.subAssemblyId,\n      singleReject: approvalGroup.singleReject,\n      quorum: approvalGroup.quorum,\n      subAssemblyCipherData: await this.keyGraph.encryptToString(\n        assemblyKey,\n        approvalGroup.plainSubAssemblyCipherData\n      ),\n      createApprovers: approvers.filter((x) => !x.approverId),\n      updateApprovers: approvers.filter((x) => x.approverId),\n      deleteApprovers: approvalGroup.deletedApproverIds || [],\n    };\n  }\n\n  private async mapApprovers(\n    approvers: UpdateScenarioApprover[],\n    quorum: number,\n    subAssembly: slip.SubAssembly,\n    assemblyKey: JWK.Key\n  ) {\n    const { k: rawAssemblyKey, ...assemblyKeyParams } = assemblyKey.toJSON(\n      true\n    ) as any;\n    let shareIdx = 0;\n\n    const nextPartialAssemblyKey = async (sharedKeyJwk: JWK.Key) => {\n      const share = subAssembly.shares[shareIdx];\n      // If quorum is 1, then using the same share for every member.\n      if (quorum !== 1) {\n        ++shareIdx;\n      }\n      const partialAssemblyKey: PartialAssemblyKey = {\n        slip39: {\n          share,\n          subAssembly: {\n            quorum,\n            size: approvers.length,\n          },\n        },\n        assemblyKeyParams,\n      };\n      return this.keyGraph.encryptToString(sharedKeyJwk, partialAssemblyKey);\n    };\n\n    return await Promise.all(\n      approvers.map(async (x) => {\n        if (x.approverId) {\n          const sharedKey = await this.keyGraph.getKey(x.keyId);\n          const sharedCipherData = await this.keyGraph.encryptToString(\n            x.keyId,\n            x.plainSharedCipherData\n          );\n          const sharedCipherApprovalData = await this.keyGraph.encryptToString(\n            x.keyId,\n            x.approvalData\n          );\n\n          return {\n            approverId: x.approverId,\n            sharedKeyId: x.keyId,\n            sharedCipherData: sharedCipherData || '',\n            sharedCipherApprovalData: sharedCipherApprovalData || '',\n            sharedCipherPartialAssemblyKey: await nextPartialAssemblyKey(\n              sharedKey.jwk\n            ),\n          };\n        } else {\n          const wrappedContent = await this.keyMetaService.wrapContentWithKey(\n            x.plainSharedCipherData,\n            x.trustedPartySharedKeyId\n          );\n\n          return {\n            tpId: x.trustedPartyId,\n            tpSharedKeyId: x.trustedPartySharedKeyId,\n            tpSharedKeyWrappedSharedKey: wrappedContent.rootKey.wrappedKey,\n            sharedCipherData: wrappedContent.cipherMeta,\n            sharedCipherApprovalData: '',\n            sharedCipherPartialAssemblyKey: await nextPartialAssemblyKey(\n              wrappedContent.key\n            ),\n          };\n        }\n      })\n    );\n  }\n\n  // Split assembly key between all existing approvers.\n  private async createSlipAssembly(\n    quorum: number,\n    approvalGroups: UpdateScenarioApprovalGroup[],\n    rawAssemblyKey: string\n  ): Promise<slip.Assembly> {\n    const slipAssembly = new slip.Assembly(quorum);\n\n    approvalGroups.forEach((x, index) => {\n      let approverCount = x.approvers.length;\n\n      // slip39 restricts quorum == 1 to have only 1 member. So we just share the same\n      // partial key for all sub assembly members.\n      if (x.quorum === 1) {\n        approverCount = 1;\n      }\n      slipAssembly.addSubAssembly(\n        new slip.SubAssembly(index, x.quorum, approverCount)\n      );\n    });\n    // Is there enough sub assemblies to meet quorum\n    if (slipAssembly.subAssemblies.length < quorum) {\n      return null;\n    }\n    await this.slip39Service.generateShares(\n      rawAssemblyKey,\n      ScenarioApproverService.SLIP39_PASSPHRASE,\n      slipAssembly\n    );\n    return slipAssembly;\n  }\n}\n"]}
1
+ import { __awaiter, __rest } from "tslib";
2
+ import { Injectable } from '@angular/core';
3
+ import { LrApolloService } from '../../api/lr-apollo.service';
4
+ import { EncryptionService } from '../../cryptography/encryption.service';
5
+ import { KeyFactoryService } from '../../cryptography/key-factory.service';
6
+ import { KeyGraphService } from '../../cryptography/key-graph.service';
7
+ import { KeyMetaService } from '../../cryptography/key-meta.service';
8
+ import * as slip from '../../cryptography/slip39.service';
9
+ import { TrustedPartyService } from '../../trusted-parties/trusted-party.service';
10
+ import { CreateScenarioApproverAssemblyMutation, DeleteScenarioApproverAssemblyMutation, GetScenarioApproverQuery, UpdateScenarioApproverAssemblyMutation, UpdateScenarioApproverMutation, } from './scenario-approval.gql';
11
+ import * as i0 from "@angular/core";
12
+ import * as i1 from "../../api/lr-apollo.service";
13
+ import * as i2 from "../../cryptography/key-factory.service";
14
+ import * as i3 from "../../cryptography/key-meta.service";
15
+ import * as i4 from "../../cryptography/key-graph.service";
16
+ import * as i5 from "../../cryptography/slip39.service";
17
+ import * as i6 from "../../cryptography/encryption.service";
18
+ import * as i7 from "../../trusted-parties/trusted-party.service";
19
+ export class ScenarioApproverService {
20
+ constructor(lrApollo, keyFactory, keyMetaService, keyGraph, slip39Service, encryptionService, trustedPartyService) {
21
+ this.lrApollo = lrApollo;
22
+ this.keyFactory = keyFactory;
23
+ this.keyMetaService = keyMetaService;
24
+ this.keyGraph = keyGraph;
25
+ this.slip39Service = slip39Service;
26
+ this.encryptionService = encryptionService;
27
+ this.trustedPartyService = trustedPartyService;
28
+ }
29
+ getApprover(approverId) {
30
+ return __awaiter(this, void 0, void 0, function* () {
31
+ const { scenarioApprover } = yield this.lrApollo.query({
32
+ query: GetScenarioApproverQuery,
33
+ variables: {
34
+ id: approverId,
35
+ },
36
+ });
37
+ return this.mapApprover(scenarioApprover);
38
+ });
39
+ }
40
+ mapApproverGroup(group) {
41
+ return __awaiter(this, void 0, void 0, function* () {
42
+ const { name } = yield this.keyGraph.decryptFromString(group.assemblyKey.id, group.subAssemblyCipherData);
43
+ return {
44
+ id: group.id,
45
+ keyId: group.assemblyKey.id,
46
+ name,
47
+ quorum: group.quorum,
48
+ singleReject: group.singleReject,
49
+ approvers: yield Promise.all(group.approvers.edges.map((x) => this.mapApprover(x.node))),
50
+ };
51
+ });
52
+ }
53
+ mapApprover(approver) {
54
+ return __awaiter(this, void 0, void 0, function* () {
55
+ const { message } = yield this.keyGraph.decryptFromString(approver.sharedKey.id, approver.sharedCipherData);
56
+ return {
57
+ id: approver.id,
58
+ keyId: approver.sharedKey.id,
59
+ trustedParty: yield this.trustedPartyService.mapTrustedParty(approver.tp),
60
+ message,
61
+ };
62
+ });
63
+ }
64
+ updateApprover(approver) {
65
+ return __awaiter(this, void 0, void 0, function* () {
66
+ const sharedCipherData = yield this.keyGraph.encryptToString(approver.keyId, approver.plainSharedCipherData);
67
+ yield this.lrApollo.mutate({
68
+ mutation: UpdateScenarioApproverMutation,
69
+ variables: {
70
+ input: {
71
+ approverId: approver.approverId,
72
+ sharedKeyId: approver.keyId,
73
+ sharedCipherData,
74
+ sharedCipherApprovalData: '',
75
+ },
76
+ },
77
+ });
78
+ });
79
+ }
80
+ createScenarioApproverAssembly(input) {
81
+ return __awaiter(this, void 0, void 0, function* () {
82
+ const assemblyKey = yield this.keyFactory.createKey();
83
+ const subjectKeyWrappedAssemblyKey = yield this.keyGraph.encryptToString(input.keyId, assemblyKey.toJSON(true));
84
+ const assemblyCipherData = input.plainAssemblyCipherData
85
+ ? yield this.keyGraph.encryptToString(assemblyKey, input.plainAssemblyCipherData)
86
+ : '';
87
+ const { createScenarioApproverAssembly } = yield this.lrApollo.mutate({
88
+ mutation: CreateScenarioApproverAssemblyMutation,
89
+ variables: {
90
+ input: {
91
+ scenarioId: input.scenarioId,
92
+ singleReject: input.singleReject,
93
+ quorum: input.quorum,
94
+ subjectKeyId: input.keyId,
95
+ subjectKeyWrappedAssemblyKey,
96
+ assemblyCipherData,
97
+ createSubAssemblies: (yield this.mapApprovalGroups(input.approvalGroups, input.quorum, assemblyKey)).map((x) => {
98
+ const { updateApprovers, deleteApprovers } = x, subAssembly = __rest(x, ["updateApprovers", "deleteApprovers"]);
99
+ return subAssembly;
100
+ }),
101
+ updateReceivers: yield this.rewrapReceivers(assemblyKey, input.event, input.receivers),
102
+ },
103
+ },
104
+ });
105
+ return createScenarioApproverAssembly.scenario.approverAssembly.assemblyKey
106
+ .id;
107
+ });
108
+ }
109
+ updateScenarioApproverAssembly(input) {
110
+ return __awaiter(this, void 0, void 0, function* () {
111
+ const assemblyKey = yield this.keyGraph.getKey(input.assemblyKeyId);
112
+ const assemblyCipherData = input.plainAssemblyCipherData
113
+ ? yield this.keyGraph.encryptToString(assemblyKey.jwk, input.plainAssemblyCipherData)
114
+ : '';
115
+ const approvalGroups = yield this.mapApprovalGroups(input.approvalGroups, input.quorum, assemblyKey.jwk);
116
+ yield this.lrApollo.mutate({
117
+ mutation: UpdateScenarioApproverAssemblyMutation,
118
+ variables: {
119
+ input: {
120
+ scenarioId: input.scenarioId,
121
+ singleReject: input.singleReject,
122
+ quorum: input.quorum,
123
+ assemblyKeyId: assemblyKey.id,
124
+ assemblyCipherData,
125
+ createSubAssemblies: approvalGroups
126
+ .filter((x) => !x.subAssemblyId)
127
+ .map((x) => {
128
+ const { updateApprovers, deleteApprovers } = x, subAssembly = __rest(x, ["updateApprovers", "deleteApprovers"]);
129
+ return subAssembly;
130
+ }),
131
+ updateSubAssemblies: approvalGroups.filter((x) => x.subAssemblyId),
132
+ deleteSubAssemblies: input.deletedGroupIds,
133
+ },
134
+ },
135
+ });
136
+ });
137
+ }
138
+ deleteScenarioApproverAssembly(scenarioId, event, receivers) {
139
+ return __awaiter(this, void 0, void 0, function* () {
140
+ yield this.lrApollo.mutate({
141
+ mutation: DeleteScenarioApproverAssemblyMutation,
142
+ variables: {
143
+ input: {
144
+ scenarioId,
145
+ updateReceivers: yield this.rewrapReceivers(null, event, receivers),
146
+ },
147
+ },
148
+ });
149
+ });
150
+ }
151
+ rewrapReceivers(assemblyKey, event, receivers) {
152
+ return __awaiter(this, void 0, void 0, function* () {
153
+ if (!receivers || !receivers.length) {
154
+ return [];
155
+ }
156
+ return yield Promise.all(receivers.map((receiver) => __awaiter(this, void 0, void 0, function* () {
157
+ const sharedKey = yield this.keyGraph.getKey(receiver.keyId);
158
+ const prepareReceiverItem = (item, itemKeyId) => __awaiter(this, void 0, void 0, function* () {
159
+ const itemKey = yield this.keyGraph.getKey(itemKeyId);
160
+ let wrappedItemKey = yield this.keyGraph.encryptToString(sharedKey.jwk, itemKey.jwk.toJSON(true));
161
+ if (assemblyKey) {
162
+ wrappedItemKey = yield this.keyGraph.encryptToString(assemblyKey, wrappedItemKey);
163
+ }
164
+ return {
165
+ accessRole: item.accessLevel,
166
+ sharedKeyId: sharedKey.id,
167
+ sharedCipherData: '',
168
+ wrappedItemKey,
169
+ };
170
+ });
171
+ // For each receiver-directory
172
+ const receiverDirectories = yield Promise.all([
173
+ ...receiver.categories.map((x) => __awaiter(this, void 0, void 0, function* () {
174
+ return (Object.assign(Object.assign({}, (yield prepareReceiverItem(x, x.category.keyId))), { receiverDirectoryId: x.id }));
175
+ })),
176
+ ...receiver.records.map((x) => __awaiter(this, void 0, void 0, function* () {
177
+ return (Object.assign(Object.assign({}, (yield prepareReceiverItem(x, x.record.keyId))), { receiverDirectoryId: x.id }));
178
+ })),
179
+ ]);
180
+ return {
181
+ receiverId: receiver.id,
182
+ sharedKeyId: receiver.keyId,
183
+ receiverDirectories,
184
+ receiverFiles: [],
185
+ sharedCipherData: yield this.keyGraph.encryptToString(sharedKey.jwk, {
186
+ event,
187
+ message: receiver.message,
188
+ }),
189
+ };
190
+ })));
191
+ });
192
+ }
193
+ mapApprovalGroups(approvalGroups, quorum, assemblyKey) {
194
+ return __awaiter(this, void 0, void 0, function* () {
195
+ const slipAssembly = yield this.createSlipAssembly(quorum, approvalGroups, assemblyKey.toJSON(true).k);
196
+ return yield Promise.all(approvalGroups.map((x, index) => this.mapApprovalGroup(x, slipAssembly.subAssemblies[index], assemblyKey)));
197
+ });
198
+ }
199
+ mapApprovalGroup(approvalGroup, subAssembly, assemblyKey) {
200
+ return __awaiter(this, void 0, void 0, function* () {
201
+ const approvers = yield this.mapApprovers(approvalGroup.approvers, approvalGroup.quorum, subAssembly, assemblyKey);
202
+ return {
203
+ subAssemblyId: approvalGroup.subAssemblyId,
204
+ singleReject: approvalGroup.singleReject,
205
+ quorum: approvalGroup.quorum,
206
+ subAssemblyCipherData: yield this.keyGraph.encryptToString(assemblyKey, approvalGroup.plainSubAssemblyCipherData),
207
+ createApprovers: approvers.filter((x) => !x.approverId),
208
+ updateApprovers: approvers.filter((x) => x.approverId),
209
+ deleteApprovers: approvalGroup.deletedApproverIds || [],
210
+ };
211
+ });
212
+ }
213
+ mapApprovers(approvers, quorum, subAssembly, assemblyKey) {
214
+ return __awaiter(this, void 0, void 0, function* () {
215
+ const _a = assemblyKey.toJSON(true), { k: rawAssemblyKey } = _a, assemblyKeyParams = __rest(_a, ["k"]);
216
+ let shareIdx = 0;
217
+ const nextPartialAssemblyKey = (sharedKeyJwk) => __awaiter(this, void 0, void 0, function* () {
218
+ const share = subAssembly.shares[shareIdx];
219
+ // If quorum is 1, then using the same share for every member.
220
+ if (quorum !== 1) {
221
+ ++shareIdx;
222
+ }
223
+ const partialAssemblyKey = {
224
+ slip39: {
225
+ share,
226
+ subAssembly: {
227
+ quorum,
228
+ size: approvers.length,
229
+ },
230
+ },
231
+ assemblyKeyParams,
232
+ };
233
+ return this.keyGraph.encryptToString(sharedKeyJwk, partialAssemblyKey);
234
+ });
235
+ return yield Promise.all(approvers.map((x) => __awaiter(this, void 0, void 0, function* () {
236
+ if (x.approverId) {
237
+ const sharedKey = yield this.keyGraph.getKey(x.keyId);
238
+ const sharedCipherData = yield this.keyGraph.encryptToString(x.keyId, x.plainSharedCipherData);
239
+ const sharedCipherApprovalData = yield this.keyGraph.encryptToString(x.keyId, x.approvalData);
240
+ return {
241
+ approverId: x.approverId,
242
+ sharedKeyId: x.keyId,
243
+ sharedCipherData: sharedCipherData || '',
244
+ sharedCipherApprovalData: sharedCipherApprovalData || '',
245
+ sharedCipherPartialAssemblyKey: yield nextPartialAssemblyKey(sharedKey.jwk),
246
+ };
247
+ }
248
+ else {
249
+ const wrappedContent = yield this.keyMetaService.wrapContentWithKey(x.plainSharedCipherData, x.trustedPartySharedKeyId);
250
+ return {
251
+ tpId: x.trustedPartyId,
252
+ tpSharedKeyId: x.trustedPartySharedKeyId,
253
+ tpSharedKeyWrappedSharedKey: wrappedContent.rootKey.wrappedKey,
254
+ sharedCipherData: wrappedContent.cipherMeta,
255
+ sharedCipherApprovalData: '',
256
+ sharedCipherPartialAssemblyKey: yield nextPartialAssemblyKey(wrappedContent.key),
257
+ };
258
+ }
259
+ })));
260
+ });
261
+ }
262
+ // Split assembly key between all existing approvers.
263
+ createSlipAssembly(quorum, approvalGroups, rawAssemblyKey) {
264
+ return __awaiter(this, void 0, void 0, function* () {
265
+ const slipAssembly = new slip.Assembly(quorum);
266
+ approvalGroups.forEach((x, index) => {
267
+ let approverCount = x.approvers.length;
268
+ // slip39 restricts quorum == 1 to have only 1 member. So we just share the same
269
+ // partial key for all sub assembly members.
270
+ if (x.quorum === 1) {
271
+ approverCount = 1;
272
+ }
273
+ slipAssembly.addSubAssembly(new slip.SubAssembly(index, x.quorum, approverCount));
274
+ });
275
+ // Is there enough sub assemblies to meet quorum
276
+ if (slipAssembly.subAssemblies.length < quorum) {
277
+ return null;
278
+ }
279
+ yield this.slip39Service.generateShares(rawAssemblyKey, ScenarioApproverService.SLIP39_PASSPHRASE, slipAssembly);
280
+ return slipAssembly;
281
+ });
282
+ }
283
+ }
284
+ ScenarioApproverService.SLIP39_PASSPHRASE = 'lifeready';
285
+ ScenarioApproverService.ɵprov = i0.ɵɵdefineInjectable({ factory: function ScenarioApproverService_Factory() { return new ScenarioApproverService(i0.ɵɵinject(i1.LrApolloService), i0.ɵɵinject(i2.KeyFactoryService), i0.ɵɵinject(i3.KeyMetaService), i0.ɵɵinject(i4.KeyGraphService), i0.ɵɵinject(i5.Slip39Service), i0.ɵɵinject(i6.EncryptionService), i0.ɵɵinject(i7.TrustedPartyService)); }, token: ScenarioApproverService, providedIn: "root" });
286
+ ScenarioApproverService.decorators = [
287
+ { type: Injectable, args: [{
288
+ providedIn: 'root',
289
+ },] }
290
+ ];
291
+ ScenarioApproverService.ctorParameters = () => [
292
+ { type: LrApolloService },
293
+ { type: KeyFactoryService },
294
+ { type: KeyMetaService },
295
+ { type: KeyGraphService },
296
+ { type: slip.Slip39Service },
297
+ { type: EncryptionService },
298
+ { type: TrustedPartyService }
299
+ ];
300
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scenario-approver.service.js","sourceRoot":"C:/Projects/newrepo/kc-client/projects/core/src/","sources":["lib/scenario/approvals/scenario-approver.service.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAE3C,OAAO,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAC9D,OAAO,EAAE,iBAAiB,EAAE,MAAM,uCAAuC,CAAC;AAC1E,OAAO,EAAE,iBAAiB,EAAE,MAAM,wCAAwC,CAAC;AAC3E,OAAO,EAAE,eAAe,EAAE,MAAM,sCAAsC,CAAC;AACvE,OAAO,EAAE,cAAc,EAAE,MAAM,qCAAqC,CAAC;AACrE,OAAO,KAAK,IAAI,MAAM,mCAAmC,CAAC;AAC1D,OAAO,EAAE,mBAAmB,EAAE,MAAM,6CAA6C,CAAC;AAOlF,OAAO,EACL,sCAAsC,EACtC,sCAAsC,EACtC,wBAAwB,EACxB,sCAAsC,EACtC,8BAA8B,GAC/B,MAAM,yBAAyB,CAAC;;;;;;;;;AAajC,MAAM,OAAO,uBAAuB;IAGlC,YACU,QAAyB,EACzB,UAA6B,EAC7B,cAA8B,EAC9B,QAAyB,EACzB,aAAiC,EACjC,iBAAoC,EACpC,mBAAwC;QANxC,aAAQ,GAAR,QAAQ,CAAiB;QACzB,eAAU,GAAV,UAAU,CAAmB;QAC7B,mBAAc,GAAd,cAAc,CAAgB;QAC9B,aAAQ,GAAR,QAAQ,CAAiB;QACzB,kBAAa,GAAb,aAAa,CAAoB;QACjC,sBAAiB,GAAjB,iBAAiB,CAAmB;QACpC,wBAAmB,GAAnB,mBAAmB,CAAqB;IAC/C,CAAC;IAES,WAAW,CAAC,UAAkB;;YACzC,MAAM,EAAE,gBAAgB,EAAE,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAM;gBAC1D,KAAK,EAAE,wBAAwB;gBAC/B,SAAS,EAAE;oBACT,EAAE,EAAE,UAAU;iBACf;aACF,CAAC,CAAC;YACH,OAAO,IAAI,CAAC,WAAW,CAAC,gBAAgB,CAAC,CAAC;QAC5C,CAAC;KAAA;IAEY,gBAAgB,CAAC,KAAU;;YACtC,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,iBAAiB,CAEnD,KAAK,CAAC,WAAW,CAAC,EAAE,EAAE,KAAK,CAAC,qBAAqB,CAAC,CAAC;YAEtD,OAAO;gBACL,EAAE,EAAE,KAAK,CAAC,EAAE;gBACZ,KAAK,EAAE,KAAK,CAAC,WAAW,CAAC,EAAE;gBAC3B,IAAI;gBACJ,MAAM,EAAE,KAAK,CAAC,MAAM;gBACpB,YAAY,EAAE,KAAK,CAAC,YAAY;gBAChC,SAAS,EAAE,MAAM,OAAO,CAAC,GAAG,CAC1B,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAC3D;aACF,CAAC;QACJ,CAAC;KAAA;IAEa,WAAW,CAAC,QAAa;;YACrC,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,iBAAiB,CAEtD,QAAQ,CAAC,SAAS,CAAC,EAAE,EAAE,QAAQ,CAAC,gBAAgB,CAAC,CAAC;YAErD,OAAO;gBACL,EAAE,EAAE,QAAQ,CAAC,EAAE;gBACf,KAAK,EAAE,QAAQ,CAAC,SAAS,CAAC,EAAE;gBAC5B,YAAY,EAAE,MAAM,IAAI,CAAC,mBAAmB,CAAC,eAAe,CAAC,QAAQ,CAAC,EAAE,CAAC;gBACzE,OAAO;aACR,CAAC;QACJ,CAAC;KAAA;IAEY,cAAc,CAAC,QAAgC;;YAC1D,MAAM,gBAAgB,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,eAAe,CAC1D,QAAQ,CAAC,KAAK,EACd,QAAQ,CAAC,qBAAqB,CAC/B,CAAC;YAEF,MAAM,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAM;gBAC9B,QAAQ,EAAE,8BAA8B;gBACxC,SAAS,EAAE;oBACT,KAAK,EAAE;wBACL,UAAU,EAAE,QAAQ,CAAC,UAAU;wBAC/B,WAAW,EAAE,QAAQ,CAAC,KAAK;wBAC3B,gBAAgB;wBAChB,wBAAwB,EAAE,EAAE;qBAC7B;iBACF;aACF,CAAC,CAAC;QACL,CAAC;KAAA;IAEY,8BAA8B,CACzC,KAAmC;;YAEnC,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC;YAEtD,MAAM,4BAA4B,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,eAAe,CACtE,KAAK,CAAC,KAAK,EACX,WAAW,CAAC,MAAM,CAAC,IAAI,CAAC,CACzB,CAAC;YAEF,MAAM,kBAAkB,GAAG,KAAK,CAAC,uBAAuB;gBACtD,CAAC,CAAC,MAAM,IAAI,CAAC,QAAQ,CAAC,eAAe,CACjC,WAAW,EACX,KAAK,CAAC,uBAAuB,CAC9B;gBACH,CAAC,CAAC,EAAE,CAAC;YAEP,MAAM,EAAE,8BAA8B,EAAE,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAM;gBACzE,QAAQ,EAAE,sCAAsC;gBAChD,SAAS,EAAE;oBACT,KAAK,EAAE;wBACL,UAAU,EAAE,KAAK,CAAC,UAAU;wBAC5B,YAAY,EAAE,KAAK,CAAC,YAAY;wBAChC,MAAM,EAAE,KAAK,CAAC,MAAM;wBACpB,YAAY,EAAE,KAAK,CAAC,KAAK;wBACzB,4BAA4B;wBAC5B,kBAAkB;wBAClB,mBAAmB,EAAE,CACnB,MAAM,IAAI,CAAC,iBAAiB,CAC1B,KAAK,CAAC,cAAc,EACpB,KAAK,CAAC,MAAM,EACZ,WAAW,CACZ,CACF,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;4BACV,MAAM,EAAE,eAAe,EAAE,eAAe,KAAqB,CAAC,EAAjB,WAAW,UAAK,CAAC,EAAxD,sCAAoD,CAAI,CAAC;4BAC/D,OAAO,WAAW,CAAC;wBACrB,CAAC,CAAC;wBACF,eAAe,EAAE,MAAM,IAAI,CAAC,eAAe,CACzC,WAAW,EACX,KAAK,CAAC,KAAK,EACX,KAAK,CAAC,SAAS,CAChB;qBACF;iBACF;aACF,CAAC,CAAC;YACH,OAAO,8BAA8B,CAAC,QAAQ,CAAC,gBAAgB,CAAC,WAAW;iBACxE,EAAE,CAAC;QACR,CAAC;KAAA;IAEY,8BAA8B,CACzC,KAAmC;;YAEnC,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;YACpE,MAAM,kBAAkB,GAAG,KAAK,CAAC,uBAAuB;gBACtD,CAAC,CAAC,MAAM,IAAI,CAAC,QAAQ,CAAC,eAAe,CACjC,WAAW,CAAC,GAAG,EACf,KAAK,CAAC,uBAAuB,CAC9B;gBACH,CAAC,CAAC,EAAE,CAAC;YAEP,MAAM,cAAc,GAAG,MAAM,IAAI,CAAC,iBAAiB,CACjD,KAAK,CAAC,cAAc,EACpB,KAAK,CAAC,MAAM,EACZ,WAAW,CAAC,GAAG,CAChB,CAAC;YAEF,MAAM,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAM;gBAC9B,QAAQ,EAAE,sCAAsC;gBAChD,SAAS,EAAE;oBACT,KAAK,EAAE;wBACL,UAAU,EAAE,KAAK,CAAC,UAAU;wBAC5B,YAAY,EAAE,KAAK,CAAC,YAAY;wBAChC,MAAM,EAAE,KAAK,CAAC,MAAM;wBACpB,aAAa,EAAE,WAAW,CAAC,EAAE;wBAC7B,kBAAkB;wBAClB,mBAAmB,EAAE,cAAc;6BAChC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC;6BAC/B,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;4BACT,MAAM,EAAE,eAAe,EAAE,eAAe,KAAqB,CAAC,EAAjB,WAAW,UAAK,CAAC,EAAxD,sCAAoD,CAAI,CAAC;4BAC/D,OAAO,WAAW,CAAC;wBACrB,CAAC,CAAC;wBACJ,mBAAmB,EAAE,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC;wBAClE,mBAAmB,EAAE,KAAK,CAAC,eAAe;qBAC3C;iBACF;aACF,CAAC,CAAC;QACL,CAAC;KAAA;IAEY,8BAA8B,CACzC,UAAkB,EAClB,KAAa,EACb,SAAqB;;YAErB,MAAM,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAM;gBAC9B,QAAQ,EAAE,sCAAsC;gBAChD,SAAS,EAAE;oBACT,KAAK,EAAE;wBACL,UAAU;wBACV,eAAe,EAAE,MAAM,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,KAAK,EAAE,SAAS,CAAC;qBACpE;iBACF;aACF,CAAC,CAAC;QACL,CAAC;KAAA;IAEa,eAAe,CAC3B,WAAoB,EACpB,KAAa,EACb,SAAqB;;YAErB,IAAI,CAAC,SAAS,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE;gBACnC,OAAO,EAAE,CAAC;aACX;YAED,OAAO,MAAM,OAAO,CAAC,GAAG,CACtB,SAAS,CAAC,GAAG,CAAC,CAAO,QAAQ,EAAE,EAAE;gBAC/B,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;gBAE7D,MAAM,mBAAmB,GAAG,CAC1B,IAAuC,EACvC,SAAiB,EACjB,EAAE;oBACF,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;oBACtD,IAAI,cAAc,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,eAAe,CACtD,SAAS,CAAC,GAAG,EACb,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,CACzB,CAAC;oBAEF,IAAI,WAAW,EAAE;wBACf,cAAc,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,eAAe,CAClD,WAAW,EACX,cAAc,CACf,CAAC;qBACH;oBAED,OAAO;wBACL,UAAU,EAAE,IAAI,CAAC,WAAW;wBAC5B,WAAW,EAAE,SAAS,CAAC,EAAE;wBACzB,gBAAgB,EAAE,EAAE;wBACpB,cAAc;qBACf,CAAC;gBACJ,CAAC,CAAA,CAAC;gBAEF,8BAA8B;gBAC9B,MAAM,mBAAmB,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;oBAC5C,GAAG,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC,CAAO,CAAC,EAAE,EAAE;wBAAC,OAAA,iCACnC,CAAC,MAAM,mBAAmB,CAAC,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,KACnD,mBAAmB,EAAE,CAAC,CAAC,EAAE,IACzB,CAAA;sBAAA,CAAC;oBACH,GAAG,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,CAAO,CAAC,EAAE,EAAE;wBAAC,OAAA,iCAChC,CAAC,MAAM,mBAAmB,CAAC,CAAC,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,KACjD,mBAAmB,EAAE,CAAC,CAAC,EAAE,IACzB,CAAA;sBAAA,CAAC;iBACJ,CAAC,CAAC;gBAEH,OAAO;oBACL,UAAU,EAAE,QAAQ,CAAC,EAAE;oBACvB,WAAW,EAAE,QAAQ,CAAC,KAAK;oBAC3B,mBAAmB;oBACnB,aAAa,EAAE,EAAE;oBACjB,gBAAgB,EAAE,MAAM,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,SAAS,CAAC,GAAG,EAAE;wBACnE,KAAK;wBACL,OAAO,EAAE,QAAQ,CAAC,OAAO;qBAC1B,CAAC;iBACH,CAAC;YACJ,CAAC,CAAA,CAAC,CACH,CAAC;QACJ,CAAC;KAAA;IAEa,iBAAiB,CAC7B,cAA6C,EAC7C,MAAc,EACd,WAAoB;;YAEpB,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAChD,MAAM,EACN,cAAc,EACb,WAAW,CAAC,MAAM,CAAC,IAAI,CAAS,CAAC,CAAC,CACpC,CAAC;YACF,OAAO,MAAM,OAAO,CAAC,GAAG,CACtB,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,CAC9B,IAAI,CAAC,gBAAgB,CAAC,CAAC,EAAE,YAAY,CAAC,aAAa,CAAC,KAAK,CAAC,EAAE,WAAW,CAAC,CACzE,CACF,CAAC;QACJ,CAAC;KAAA;IAEa,gBAAgB,CAC5B,aAA0C,EAC1C,WAA6B,EAC7B,WAAoB;;YAEpB,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,YAAY,CACvC,aAAa,CAAC,SAAS,EACvB,aAAa,CAAC,MAAM,EACpB,WAAW,EACX,WAAW,CACZ,CAAC;YAEF,OAAO;gBACL,aAAa,EAAE,aAAa,CAAC,aAAa;gBAC1C,YAAY,EAAE,aAAa,CAAC,YAAY;gBACxC,MAAM,EAAE,aAAa,CAAC,MAAM;gBAC5B,qBAAqB,EAAE,MAAM,IAAI,CAAC,QAAQ,CAAC,eAAe,CACxD,WAAW,EACX,aAAa,CAAC,0BAA0B,CACzC;gBACD,eAAe,EAAE,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC;gBACvD,eAAe,EAAE,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC;gBACtD,eAAe,EAAE,aAAa,CAAC,kBAAkB,IAAI,EAAE;aACxD,CAAC;QACJ,CAAC;KAAA;IAEa,YAAY,CACxB,SAAmC,EACnC,MAAc,EACd,WAA6B,EAC7B,WAAoB;;YAEpB,MAAM,KAA8C,WAAW,CAAC,MAAM,CACpE,IAAI,CACE,EAFF,EAAE,CAAC,EAAE,cAAc,OAEjB,EAFsB,iBAAiB,cAAzC,KAA2C,CAEzC,CAAC;YACT,IAAI,QAAQ,GAAG,CAAC,CAAC;YAEjB,MAAM,sBAAsB,GAAG,CAAO,YAAqB,EAAE,EAAE;gBAC7D,MAAM,KAAK,GAAG,WAAW,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;gBAC3C,8DAA8D;gBAC9D,IAAI,MAAM,KAAK,CAAC,EAAE;oBAChB,EAAE,QAAQ,CAAC;iBACZ;gBACD,MAAM,kBAAkB,GAAuB;oBAC7C,MAAM,EAAE;wBACN,KAAK;wBACL,WAAW,EAAE;4BACX,MAAM;4BACN,IAAI,EAAE,SAAS,CAAC,MAAM;yBACvB;qBACF;oBACD,iBAAiB;iBAClB,CAAC;gBACF,OAAO,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,YAAY,EAAE,kBAAkB,CAAC,CAAC;YACzE,CAAC,CAAA,CAAC;YAEF,OAAO,MAAM,OAAO,CAAC,GAAG,CACtB,SAAS,CAAC,GAAG,CAAC,CAAO,CAAC,EAAE,EAAE;gBACxB,IAAI,CAAC,CAAC,UAAU,EAAE;oBAChB,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;oBACtD,MAAM,gBAAgB,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,eAAe,CAC1D,CAAC,CAAC,KAAK,EACP,CAAC,CAAC,qBAAqB,CACxB,CAAC;oBACF,MAAM,wBAAwB,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,eAAe,CAClE,CAAC,CAAC,KAAK,EACP,CAAC,CAAC,YAAY,CACf,CAAC;oBAEF,OAAO;wBACL,UAAU,EAAE,CAAC,CAAC,UAAU;wBACxB,WAAW,EAAE,CAAC,CAAC,KAAK;wBACpB,gBAAgB,EAAE,gBAAgB,IAAI,EAAE;wBACxC,wBAAwB,EAAE,wBAAwB,IAAI,EAAE;wBACxD,8BAA8B,EAAE,MAAM,sBAAsB,CAC1D,SAAS,CAAC,GAAG,CACd;qBACF,CAAC;iBACH;qBAAM;oBACL,MAAM,cAAc,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,kBAAkB,CACjE,CAAC,CAAC,qBAAqB,EACvB,CAAC,CAAC,uBAAuB,CAC1B,CAAC;oBAEF,OAAO;wBACL,IAAI,EAAE,CAAC,CAAC,cAAc;wBACtB,aAAa,EAAE,CAAC,CAAC,uBAAuB;wBACxC,2BAA2B,EAAE,cAAc,CAAC,OAAO,CAAC,UAAU;wBAC9D,gBAAgB,EAAE,cAAc,CAAC,UAAU;wBAC3C,wBAAwB,EAAE,EAAE;wBAC5B,8BAA8B,EAAE,MAAM,sBAAsB,CAC1D,cAAc,CAAC,GAAG,CACnB;qBACF,CAAC;iBACH;YACH,CAAC,CAAA,CAAC,CACH,CAAC;QACJ,CAAC;KAAA;IAED,qDAAqD;IACvC,kBAAkB,CAC9B,MAAc,EACd,cAA6C,EAC7C,cAAsB;;YAEtB,MAAM,YAAY,GAAG,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;YAE/C,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE;gBAClC,IAAI,aAAa,GAAG,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC;gBAEvC,gFAAgF;gBAChF,4CAA4C;gBAC5C,IAAI,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE;oBAClB,aAAa,GAAG,CAAC,CAAC;iBACnB;gBACD,YAAY,CAAC,cAAc,CACzB,IAAI,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC,CAAC,MAAM,EAAE,aAAa,CAAC,CACrD,CAAC;YACJ,CAAC,CAAC,CAAC;YACH,gDAAgD;YAChD,IAAI,YAAY,CAAC,aAAa,CAAC,MAAM,GAAG,MAAM,EAAE;gBAC9C,OAAO,IAAI,CAAC;aACb;YACD,MAAM,IAAI,CAAC,aAAa,CAAC,cAAc,CACrC,cAAc,EACd,uBAAuB,CAAC,iBAAiB,EACzC,YAAY,CACb,CAAC;YACF,OAAO,YAAY,CAAC;QACtB,CAAC;KAAA;;AAjYa,yCAAiB,GAAG,WAAW,CAAC;;;YAJ/C,UAAU,SAAC;gBACV,UAAU,EAAE,MAAM;aACnB;;;YA/BQ,eAAe;YAEf,iBAAiB;YAEjB,cAAc;YADd,eAAe;YAEZ,IAAI,CAmCgB,aAAa;YAvCpC,iBAAiB;YAKjB,mBAAmB","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { JWK } from 'node-jose';\r\nimport { LrApolloService } from '../../api/lr-apollo.service';\r\nimport { EncryptionService } from '../../cryptography/encryption.service';\r\nimport { KeyFactoryService } from '../../cryptography/key-factory.service';\r\nimport { KeyGraphService } from '../../cryptography/key-graph.service';\r\nimport { KeyMetaService } from '../../cryptography/key-meta.service';\r\nimport * as slip from '../../cryptography/slip39.service';\r\nimport { TrustedPartyService } from '../../trusted-parties/trusted-party.service';\r\nimport {\r\n  Receiver,\r\n  ReceiverCategory,\r\n  ReceiverRecord,\r\n} from '../receivers/scenario-receiver.types';\r\nimport { PartialAssemblyKey } from '../scenario.types';\r\nimport {\r\n  CreateScenarioApproverAssemblyMutation,\r\n  DeleteScenarioApproverAssemblyMutation,\r\n  GetScenarioApproverQuery,\r\n  UpdateScenarioApproverAssemblyMutation,\r\n  UpdateScenarioApproverMutation,\r\n} from './scenario-approval.gql';\r\nimport {\r\n  ApprovalGroup,\r\n  Approver,\r\n  CreateScenarioApprovalGroups,\r\n  UpdateScenarioApprovalGroup,\r\n  UpdateScenarioApprovalGroups,\r\n  UpdateScenarioApprover,\r\n} from './scenario-approval.types';\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class ScenarioApproverService {\r\n  public static SLIP39_PASSPHRASE = 'lifeready';\r\n\r\n  constructor(\r\n    private lrApollo: LrApolloService,\r\n    private keyFactory: KeyFactoryService,\r\n    private keyMetaService: KeyMetaService,\r\n    private keyGraph: KeyGraphService,\r\n    private slip39Service: slip.Slip39Service,\r\n    private encryptionService: EncryptionService,\r\n    private trustedPartyService: TrustedPartyService\r\n  ) {}\r\n\r\n  public async getApprover(approverId: string): Promise<Approver> {\r\n    const { scenarioApprover } = await this.lrApollo.query<any>({\r\n      query: GetScenarioApproverQuery,\r\n      variables: {\r\n        id: approverId,\r\n      },\r\n    });\r\n    return this.mapApprover(scenarioApprover);\r\n  }\r\n\r\n  public async mapApproverGroup(group: any): Promise<ApprovalGroup> {\r\n    const { name } = await this.keyGraph.decryptFromString<{\r\n      name: string;\r\n    }>(group.assemblyKey.id, group.subAssemblyCipherData);\r\n\r\n    return {\r\n      id: group.id,\r\n      keyId: group.assemblyKey.id,\r\n      name,\r\n      quorum: group.quorum,\r\n      singleReject: group.singleReject,\r\n      approvers: await Promise.all(\r\n        group.approvers.edges.map((x) => this.mapApprover(x.node))\r\n      ),\r\n    };\r\n  }\r\n\r\n  private async mapApprover(approver: any): Promise<Approver> {\r\n    const { message } = await this.keyGraph.decryptFromString<{\r\n      message: string;\r\n    }>(approver.sharedKey.id, approver.sharedCipherData);\r\n\r\n    return {\r\n      id: approver.id,\r\n      keyId: approver.sharedKey.id,\r\n      trustedParty: await this.trustedPartyService.mapTrustedParty(approver.tp),\r\n      message,\r\n    };\r\n  }\r\n\r\n  public async updateApprover(approver: UpdateScenarioApprover): Promise<void> {\r\n    const sharedCipherData = await this.keyGraph.encryptToString(\r\n      approver.keyId,\r\n      approver.plainSharedCipherData\r\n    );\r\n\r\n    await this.lrApollo.mutate<any>({\r\n      mutation: UpdateScenarioApproverMutation,\r\n      variables: {\r\n        input: {\r\n          approverId: approver.approverId,\r\n          sharedKeyId: approver.keyId,\r\n          sharedCipherData,\r\n          sharedCipherApprovalData: '',\r\n        },\r\n      },\r\n    });\r\n  }\r\n\r\n  public async createScenarioApproverAssembly(\r\n    input: CreateScenarioApprovalGroups\r\n  ): Promise<string> {\r\n    const assemblyKey = await this.keyFactory.createKey();\r\n\r\n    const subjectKeyWrappedAssemblyKey = await this.keyGraph.encryptToString(\r\n      input.keyId,\r\n      assemblyKey.toJSON(true)\r\n    );\r\n\r\n    const assemblyCipherData = input.plainAssemblyCipherData\r\n      ? await this.keyGraph.encryptToString(\r\n          assemblyKey,\r\n          input.plainAssemblyCipherData\r\n        )\r\n      : '';\r\n\r\n    const { createScenarioApproverAssembly } = await this.lrApollo.mutate<any>({\r\n      mutation: CreateScenarioApproverAssemblyMutation,\r\n      variables: {\r\n        input: {\r\n          scenarioId: input.scenarioId,\r\n          singleReject: input.singleReject,\r\n          quorum: input.quorum,\r\n          subjectKeyId: input.keyId,\r\n          subjectKeyWrappedAssemblyKey,\r\n          assemblyCipherData,\r\n          createSubAssemblies: (\r\n            await this.mapApprovalGroups(\r\n              input.approvalGroups,\r\n              input.quorum,\r\n              assemblyKey\r\n            )\r\n          ).map((x) => {\r\n            const { updateApprovers, deleteApprovers, ...subAssembly } = x;\r\n            return subAssembly;\r\n          }),\r\n          updateReceivers: await this.rewrapReceivers(\r\n            assemblyKey,\r\n            input.event,\r\n            input.receivers\r\n          ),\r\n        },\r\n      },\r\n    });\r\n    return createScenarioApproverAssembly.scenario.approverAssembly.assemblyKey\r\n      .id;\r\n  }\r\n\r\n  public async updateScenarioApproverAssembly(\r\n    input: UpdateScenarioApprovalGroups\r\n  ): Promise<void> {\r\n    const assemblyKey = await this.keyGraph.getKey(input.assemblyKeyId);\r\n    const assemblyCipherData = input.plainAssemblyCipherData\r\n      ? await this.keyGraph.encryptToString(\r\n          assemblyKey.jwk,\r\n          input.plainAssemblyCipherData\r\n        )\r\n      : '';\r\n\r\n    const approvalGroups = await this.mapApprovalGroups(\r\n      input.approvalGroups,\r\n      input.quorum,\r\n      assemblyKey.jwk\r\n    );\r\n\r\n    await this.lrApollo.mutate<any>({\r\n      mutation: UpdateScenarioApproverAssemblyMutation,\r\n      variables: {\r\n        input: {\r\n          scenarioId: input.scenarioId,\r\n          singleReject: input.singleReject,\r\n          quorum: input.quorum,\r\n          assemblyKeyId: assemblyKey.id,\r\n          assemblyCipherData,\r\n          createSubAssemblies: approvalGroups\r\n            .filter((x) => !x.subAssemblyId)\r\n            .map((x) => {\r\n              const { updateApprovers, deleteApprovers, ...subAssembly } = x;\r\n              return subAssembly;\r\n            }),\r\n          updateSubAssemblies: approvalGroups.filter((x) => x.subAssemblyId),\r\n          deleteSubAssemblies: input.deletedGroupIds,\r\n        },\r\n      },\r\n    });\r\n  }\r\n\r\n  public async deleteScenarioApproverAssembly(\r\n    scenarioId: string,\r\n    event: string,\r\n    receivers: Receiver[]\r\n  ): Promise<void> {\r\n    await this.lrApollo.mutate<any>({\r\n      mutation: DeleteScenarioApproverAssemblyMutation,\r\n      variables: {\r\n        input: {\r\n          scenarioId,\r\n          updateReceivers: await this.rewrapReceivers(null, event, receivers),\r\n        },\r\n      },\r\n    });\r\n  }\r\n\r\n  private async rewrapReceivers(\r\n    assemblyKey: JWK.Key,\r\n    event: string,\r\n    receivers: Receiver[]\r\n  ) {\r\n    if (!receivers || !receivers.length) {\r\n      return [];\r\n    }\r\n\r\n    return await Promise.all(\r\n      receivers.map(async (receiver) => {\r\n        const sharedKey = await this.keyGraph.getKey(receiver.keyId);\r\n\r\n        const prepareReceiverItem = async (\r\n          item: ReceiverCategory | ReceiverRecord,\r\n          itemKeyId: string\r\n        ) => {\r\n          const itemKey = await this.keyGraph.getKey(itemKeyId);\r\n          let wrappedItemKey = await this.keyGraph.encryptToString(\r\n            sharedKey.jwk,\r\n            itemKey.jwk.toJSON(true)\r\n          );\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\r\n          return {\r\n            accessRole: item.accessLevel,\r\n            sharedKeyId: sharedKey.id,\r\n            sharedCipherData: '',\r\n            wrappedItemKey,\r\n          };\r\n        };\r\n\r\n        // For each receiver-directory\r\n        const receiverDirectories = await Promise.all([\r\n          ...receiver.categories.map(async (x) => ({\r\n            ...(await prepareReceiverItem(x, x.category.keyId)),\r\n            receiverDirectoryId: x.id,\r\n          })),\r\n          ...receiver.records.map(async (x) => ({\r\n            ...(await prepareReceiverItem(x, x.record.keyId)),\r\n            receiverDirectoryId: x.id,\r\n          })),\r\n        ]);\r\n\r\n        return {\r\n          receiverId: receiver.id,\r\n          sharedKeyId: receiver.keyId,\r\n          receiverDirectories,\r\n          receiverFiles: [],\r\n          sharedCipherData: await this.keyGraph.encryptToString(sharedKey.jwk, {\r\n            event,\r\n            message: receiver.message,\r\n          }),\r\n        };\r\n      })\r\n    );\r\n  }\r\n\r\n  private async mapApprovalGroups(\r\n    approvalGroups: UpdateScenarioApprovalGroup[],\r\n    quorum: number,\r\n    assemblyKey: JWK.Key\r\n  ) {\r\n    const slipAssembly = await this.createSlipAssembly(\r\n      quorum,\r\n      approvalGroups,\r\n      (assemblyKey.toJSON(true) as any).k\r\n    );\r\n    return await Promise.all(\r\n      approvalGroups.map((x, index) =>\r\n        this.mapApprovalGroup(x, slipAssembly.subAssemblies[index], assemblyKey)\r\n      )\r\n    );\r\n  }\r\n\r\n  private async mapApprovalGroup(\r\n    approvalGroup: UpdateScenarioApprovalGroup,\r\n    subAssembly: slip.SubAssembly,\r\n    assemblyKey: JWK.Key\r\n  ) {\r\n    const approvers = await this.mapApprovers(\r\n      approvalGroup.approvers,\r\n      approvalGroup.quorum,\r\n      subAssembly,\r\n      assemblyKey\r\n    );\r\n\r\n    return {\r\n      subAssemblyId: approvalGroup.subAssemblyId,\r\n      singleReject: approvalGroup.singleReject,\r\n      quorum: approvalGroup.quorum,\r\n      subAssemblyCipherData: await this.keyGraph.encryptToString(\r\n        assemblyKey,\r\n        approvalGroup.plainSubAssemblyCipherData\r\n      ),\r\n      createApprovers: approvers.filter((x) => !x.approverId),\r\n      updateApprovers: approvers.filter((x) => x.approverId),\r\n      deleteApprovers: approvalGroup.deletedApproverIds || [],\r\n    };\r\n  }\r\n\r\n  private async mapApprovers(\r\n    approvers: UpdateScenarioApprover[],\r\n    quorum: number,\r\n    subAssembly: slip.SubAssembly,\r\n    assemblyKey: JWK.Key\r\n  ) {\r\n    const { k: rawAssemblyKey, ...assemblyKeyParams } = assemblyKey.toJSON(\r\n      true\r\n    ) as any;\r\n    let shareIdx = 0;\r\n\r\n    const nextPartialAssemblyKey = async (sharedKeyJwk: JWK.Key) => {\r\n      const share = subAssembly.shares[shareIdx];\r\n      // If quorum is 1, then using the same share for every member.\r\n      if (quorum !== 1) {\r\n        ++shareIdx;\r\n      }\r\n      const partialAssemblyKey: PartialAssemblyKey = {\r\n        slip39: {\r\n          share,\r\n          subAssembly: {\r\n            quorum,\r\n            size: approvers.length,\r\n          },\r\n        },\r\n        assemblyKeyParams,\r\n      };\r\n      return this.keyGraph.encryptToString(sharedKeyJwk, partialAssemblyKey);\r\n    };\r\n\r\n    return await Promise.all(\r\n      approvers.map(async (x) => {\r\n        if (x.approverId) {\r\n          const sharedKey = await this.keyGraph.getKey(x.keyId);\r\n          const sharedCipherData = await this.keyGraph.encryptToString(\r\n            x.keyId,\r\n            x.plainSharedCipherData\r\n          );\r\n          const sharedCipherApprovalData = await this.keyGraph.encryptToString(\r\n            x.keyId,\r\n            x.approvalData\r\n          );\r\n\r\n          return {\r\n            approverId: x.approverId,\r\n            sharedKeyId: x.keyId,\r\n            sharedCipherData: sharedCipherData || '',\r\n            sharedCipherApprovalData: sharedCipherApprovalData || '',\r\n            sharedCipherPartialAssemblyKey: await nextPartialAssemblyKey(\r\n              sharedKey.jwk\r\n            ),\r\n          };\r\n        } else {\r\n          const wrappedContent = await this.keyMetaService.wrapContentWithKey(\r\n            x.plainSharedCipherData,\r\n            x.trustedPartySharedKeyId\r\n          );\r\n\r\n          return {\r\n            tpId: x.trustedPartyId,\r\n            tpSharedKeyId: x.trustedPartySharedKeyId,\r\n            tpSharedKeyWrappedSharedKey: wrappedContent.rootKey.wrappedKey,\r\n            sharedCipherData: wrappedContent.cipherMeta,\r\n            sharedCipherApprovalData: '',\r\n            sharedCipherPartialAssemblyKey: await nextPartialAssemblyKey(\r\n              wrappedContent.key\r\n            ),\r\n          };\r\n        }\r\n      })\r\n    );\r\n  }\r\n\r\n  // Split assembly key between all existing approvers.\r\n  private async createSlipAssembly(\r\n    quorum: number,\r\n    approvalGroups: UpdateScenarioApprovalGroup[],\r\n    rawAssemblyKey: string\r\n  ): Promise<slip.Assembly> {\r\n    const slipAssembly = new slip.Assembly(quorum);\r\n\r\n    approvalGroups.forEach((x, index) => {\r\n      let approverCount = x.approvers.length;\r\n\r\n      // slip39 restricts quorum == 1 to have only 1 member. So we just share the same\r\n      // partial key for all sub assembly members.\r\n      if (x.quorum === 1) {\r\n        approverCount = 1;\r\n      }\r\n      slipAssembly.addSubAssembly(\r\n        new slip.SubAssembly(index, x.quorum, approverCount)\r\n      );\r\n    });\r\n    // Is there enough sub assemblies to meet quorum\r\n    if (slipAssembly.subAssemblies.length < quorum) {\r\n      return null;\r\n    }\r\n    await this.slip39Service.generateShares(\r\n      rawAssemblyKey,\r\n      ScenarioApproverService.SLIP39_PASSPHRASE,\r\n      slipAssembly\r\n    );\r\n    return slipAssembly;\r\n  }\r\n}\r\n"]}