@lifeready/core 1.0.1 → 1.0.2

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 (380) hide show
  1. package/README.md +62 -62
  2. package/bundles/lifeready-core.umd.js +15939 -0
  3. package/bundles/lifeready-core.umd.js.map +1 -0
  4. package/bundles/lifeready-core.umd.min.js +16 -0
  5. package/bundles/lifeready-core.umd.min.js.map +1 -0
  6. package/esm2015/lib/_common/ast.js +40 -0
  7. package/esm2015/lib/_common/deferred-promise.js +24 -0
  8. package/esm2015/lib/_common/exceptions.js +157 -0
  9. package/esm2015/lib/_common/queries.gql.js +190 -0
  10. package/esm2015/lib/_common/run-outside-angular.js +79 -0
  11. package/esm2015/lib/_common/types.js +1 -0
  12. package/esm2015/lib/_common/utils.js +44 -0
  13. package/esm2015/lib/api/contact-card.gql.js +79 -0
  14. package/esm2015/lib/api/contact-card.service.js +154 -0
  15. package/esm2015/lib/api/contact-card2.gql.js +60 -0
  16. package/esm2015/lib/api/contact-card2.service.js +103 -0
  17. package/esm2015/lib/api/file.service.js +74 -0
  18. package/esm2015/lib/api/item2.gql.js +110 -0
  19. package/esm2015/lib/api/item2.service.js +311 -0
  20. package/esm2015/lib/api/key-exchange.gql.js +188 -0
  21. package/esm2015/lib/api/key-exchange.service.js +442 -0
  22. package/esm2015/lib/api/key-exchange.types.js +18 -0
  23. package/esm2015/lib/api/key-exchange2.gql.js +171 -0
  24. package/esm2015/lib/api/key-exchange2.service.js +479 -0
  25. package/esm2015/lib/api/lock.gql.js +40 -0
  26. package/esm2015/lib/api/lock.service.js +64 -0
  27. package/esm2015/lib/api/lr-apollo.service.js +46 -0
  28. package/esm2015/lib/api/lr-graphql/index.js +6 -0
  29. package/esm2015/lib/api/lr-graphql/lr-graphql.service.js +155 -0
  30. package/esm2015/lib/api/lr-graphql/lr-merged-mutation.js +213 -0
  31. package/esm2015/lib/api/lr-graphql/lr-mutation-base.js +51 -0
  32. package/esm2015/lib/api/lr-graphql/lr-mutation.js +48 -0
  33. package/esm2015/lib/api/lr-graphql/lr.service.js +18 -0
  34. package/esm2015/lib/api/message.service.js +138 -0
  35. package/esm2015/lib/api/persist.service.js +181 -0
  36. package/esm2015/lib/api/query-processor/common-processors.service.js +93 -0
  37. package/esm2015/lib/api/query-processor/index.js +3 -0
  38. package/esm2015/lib/api/query-processor/query-processor.service.js +192 -0
  39. package/esm2015/lib/api/query-processor/tp-password-reset-processor.service.js +109 -0
  40. package/esm2015/lib/api/shared-contact-card.service.js +119 -0
  41. package/esm2015/lib/api/shared-contact-card2.gql.js +41 -0
  42. package/esm2015/lib/api/shared-contact-card2.service.js +117 -0
  43. package/esm2015/lib/api/time.service.js +146 -0
  44. package/esm2015/lib/api/types/graphql.types.js +7 -0
  45. package/esm2015/lib/api/types/index.js +3 -0
  46. package/esm2015/lib/api/types/lr-graphql.types.js +71 -0
  47. package/esm2015/lib/auth/auth.config.js +57 -0
  48. package/esm2015/lib/auth/auth.gql.js +48 -0
  49. package/esm2015/lib/auth/auth.types.js +27 -0
  50. package/esm2015/lib/auth/idle.service.js +168 -0
  51. package/esm2015/lib/auth/idle.types.js +7 -0
  52. package/esm2015/lib/auth/lbop.service.js +355 -0
  53. package/esm2015/lib/auth/life-ready-auth.service.js +500 -0
  54. package/esm2015/lib/auth/password.service.js +320 -0
  55. package/esm2015/lib/auth/register.service.js +172 -0
  56. package/esm2015/lib/auth/two-factor.service.js +74 -0
  57. package/esm2015/lib/category/category-meta.service.js +99 -0
  58. package/esm2015/lib/category/category.gql.js +406 -0
  59. package/esm2015/lib/category/category.service.js +390 -0
  60. package/esm2015/lib/category/category.types.js +29 -0
  61. package/esm2015/lib/cryptography/cryptography.types.js +11 -0
  62. package/esm2015/lib/cryptography/encryption.service.js +189 -0
  63. package/esm2015/lib/cryptography/key-factory.service.js +237 -0
  64. package/esm2015/lib/cryptography/key-graph.service.js +280 -0
  65. package/esm2015/lib/cryptography/key-meta.service.js +200 -0
  66. package/esm2015/lib/cryptography/key.service.js +124 -0
  67. package/esm2015/lib/cryptography/slip39.service.js +169 -0
  68. package/esm2015/lib/cryptography/web-crypto.service.js +29 -0
  69. package/esm2015/lib/life-ready.config.js +84 -0
  70. package/esm2015/lib/life-ready.module.js +74 -0
  71. package/esm2015/lib/plan/plan.gql.js +123 -0
  72. package/esm2015/lib/plan/plan.service.js +149 -0
  73. package/esm2015/lib/plan/plan.types.js +11 -0
  74. package/esm2015/lib/record/record-attachment.service.js +101 -0
  75. package/esm2015/lib/record/record.gql.js +179 -0
  76. package/esm2015/lib/record/record.service.js +206 -0
  77. package/esm2015/lib/record/record.types.js +15 -0
  78. package/esm2015/lib/record-type/record-type.service.js +75 -0
  79. package/esm2015/lib/record-type/record-type.types.js +28 -0
  80. package/esm2015/lib/scenario/approvals/scenario-approval.gql.js +105 -0
  81. package/esm2015/lib/scenario/approvals/scenario-approval.types.js +1 -0
  82. package/esm2015/lib/scenario/approvals/scenario-approver.service.js +300 -0
  83. package/esm2015/lib/scenario/claimants/scenario-claimant.gql.js +52 -0
  84. package/esm2015/lib/scenario/claimants/scenario-claimant.service.js +97 -0
  85. package/esm2015/lib/scenario/claimants/scenario-claimant.types.js +1 -0
  86. package/esm2015/lib/scenario/receivers/scenario-receiver.gql.js +150 -0
  87. package/esm2015/lib/scenario/receivers/scenario-receiver.service.js +229 -0
  88. package/esm2015/lib/scenario/receivers/scenario-receiver.types.js +1 -0
  89. package/esm2015/lib/scenario/scenario-setup.service.js +269 -0
  90. package/esm2015/lib/scenario/scenario.gql.js +368 -0
  91. package/esm2015/lib/scenario/scenario.service.js +611 -0
  92. package/esm2015/lib/scenario/scenario.types.js +64 -0
  93. package/esm2015/lib/search/search.gql.js +62 -0
  94. package/esm2015/lib/search/search.service.js +156 -0
  95. package/esm2015/lib/search/search.types.js +6 -0
  96. package/esm2015/lib/trusted-parties/tp-password-reset-request.service.js +112 -0
  97. package/esm2015/lib/trusted-parties/tp-password-reset-user.service.js +129 -0
  98. package/esm2015/lib/trusted-parties/tp-password-reset.constants.js +4 -0
  99. package/esm2015/lib/trusted-parties/tp-password-reset.gql.js +232 -0
  100. package/esm2015/lib/trusted-parties/tp-password-reset.service.js +299 -0
  101. package/esm2015/lib/trusted-parties/trusted-party.gql.js +148 -0
  102. package/esm2015/lib/trusted-parties/trusted-party.service.js +326 -0
  103. package/esm2015/lib/trusted-parties/trusted-party.types.js +41 -0
  104. package/esm2015/lib/trusted-parties/trusted-party2.gql.js +87 -0
  105. package/esm2015/lib/trusted-parties/trusted-party2.service.js +215 -0
  106. package/esm2015/lib/users/profile-details.service.js +214 -0
  107. package/esm2015/lib/users/profile.gql.js +97 -0
  108. package/esm2015/lib/users/profile.service.js +169 -0
  109. package/esm2015/lib/users/profile.types.js +34 -0
  110. package/esm2015/lib/users/user.gql.js +60 -0
  111. package/esm2015/lib/users/user.service.js +79 -0
  112. package/esm2015/lib/users/user.types.js +5 -0
  113. package/esm2015/lifeready-core.js +10 -0
  114. package/esm2015/public-api.js +81 -0
  115. package/fesm2015/lifeready-core.js +13314 -0
  116. package/fesm2015/lifeready-core.js.map +1 -0
  117. package/lib/_common/ast.d.ts +11 -0
  118. package/lib/_common/deferred-promise.d.ts +12 -0
  119. package/lib/_common/exceptions.d.ts +109 -0
  120. package/lib/_common/queries.gql.d.ts +10 -0
  121. package/lib/_common/run-outside-angular.d.ts +14 -0
  122. package/{src/lib/_common/types.ts → lib/_common/types.d.ts} +10 -13
  123. package/lib/_common/utils.d.ts +3 -0
  124. package/lib/api/contact-card.gql.d.ts +7 -0
  125. package/lib/api/contact-card.service.d.ts +52 -0
  126. package/lib/api/contact-card2.gql.d.ts +34 -0
  127. package/lib/api/contact-card2.service.d.ts +49 -0
  128. package/lib/api/file.service.d.ts +18 -0
  129. package/lib/api/item2.gql.d.ts +96 -0
  130. package/lib/api/item2.service.d.ts +177 -0
  131. package/lib/api/key-exchange.gql.d.ts +9 -0
  132. package/lib/api/key-exchange.service.d.ts +39 -0
  133. package/lib/api/key-exchange.types.d.ts +196 -0
  134. package/lib/api/key-exchange2.gql.d.ts +125 -0
  135. package/lib/api/key-exchange2.service.d.ts +187 -0
  136. package/lib/api/lock.gql.d.ts +27 -0
  137. package/lib/api/lock.service.d.ts +25 -0
  138. package/lib/api/lr-apollo.service.d.ts +15 -0
  139. package/{src/lib/api/lr-graphql/index.ts → lib/api/lr-graphql/index.d.ts} +5 -5
  140. package/lib/api/lr-graphql/lr-graphql.service.d.ts +60 -0
  141. package/lib/api/lr-graphql/lr-merged-mutation.d.ts +27 -0
  142. package/lib/api/lr-graphql/lr-mutation-base.d.ts +28 -0
  143. package/lib/api/lr-graphql/lr-mutation.d.ts +8 -0
  144. package/lib/api/lr-graphql/lr.service.d.ts +9 -0
  145. package/lib/api/message.service.d.ts +58 -0
  146. package/lib/api/persist.service.d.ts +31 -0
  147. package/lib/api/query-processor/common-processors.service.d.ts +36 -0
  148. package/{src/lib/api/query-processor/index.ts → lib/api/query-processor/index.d.ts} +2 -2
  149. package/lib/api/query-processor/query-processor.service.d.ts +18 -0
  150. package/lib/api/query-processor/tp-password-reset-processor.service.d.ts +15 -0
  151. package/lib/api/shared-contact-card.service.d.ts +33 -0
  152. package/lib/api/shared-contact-card2.gql.d.ts +36 -0
  153. package/lib/api/shared-contact-card2.service.d.ts +45 -0
  154. package/lib/api/time.service.d.ts +16 -0
  155. package/lib/api/types/graphql.types.d.ts +29 -0
  156. package/{src/lib/api/types/index.ts → lib/api/types/index.d.ts} +2 -2
  157. package/lib/api/types/lr-graphql.types.d.ts +385 -0
  158. package/lib/auth/auth.config.d.ts +5 -0
  159. package/lib/auth/auth.gql.d.ts +15 -0
  160. package/lib/auth/auth.types.d.ts +66 -0
  161. package/lib/auth/idle.service.d.ts +40 -0
  162. package/lib/auth/idle.types.d.ts +10 -0
  163. package/lib/auth/lbop.service.d.ts +91 -0
  164. package/lib/auth/life-ready-auth.service.d.ts +59 -0
  165. package/lib/auth/password.service.d.ts +78 -0
  166. package/lib/auth/register.service.d.ts +25 -0
  167. package/lib/auth/two-factor.service.d.ts +15 -0
  168. package/lib/category/category-meta.service.d.ts +23 -0
  169. package/lib/category/category.gql.d.ts +45 -0
  170. package/lib/category/category.service.d.ts +67 -0
  171. package/lib/category/category.types.d.ts +79 -0
  172. package/lib/cryptography/cryptography.types.d.ts +83 -0
  173. package/lib/cryptography/encryption.service.d.ts +41 -0
  174. package/lib/cryptography/key-factory.service.d.ts +38 -0
  175. package/lib/cryptography/key-graph.service.d.ts +33 -0
  176. package/lib/cryptography/key-meta.service.d.ts +44 -0
  177. package/lib/cryptography/key.service.d.ts +36 -0
  178. package/lib/cryptography/slip39.service.d.ts +43 -0
  179. package/lib/cryptography/web-crypto.service.d.ts +5 -0
  180. package/lib/life-ready.config.d.ts +14 -0
  181. package/lib/life-ready.module.d.ts +5 -0
  182. package/lib/plan/plan.gql.d.ts +11 -0
  183. package/lib/plan/plan.service.d.ts +33 -0
  184. package/lib/plan/plan.types.d.ts +31 -0
  185. package/lib/record/record-attachment.service.d.ts +16 -0
  186. package/lib/record/record.gql.d.ts +14 -0
  187. package/lib/record/record.service.d.ts +25 -0
  188. package/lib/record/record.types.d.ts +57 -0
  189. package/lib/record-type/record-type.service.d.ts +11 -0
  190. package/lib/record-type/record-type.types.d.ts +50 -0
  191. package/lib/scenario/approvals/scenario-approval.gql.d.ts +7 -0
  192. package/lib/scenario/approvals/scenario-approval.types.d.ts +63 -0
  193. package/lib/scenario/approvals/scenario-approver.service.d.ts +32 -0
  194. package/lib/scenario/claimants/scenario-claimant.gql.d.ts +5 -0
  195. package/lib/scenario/claimants/scenario-claimant.service.d.ts +17 -0
  196. package/lib/scenario/claimants/scenario-claimant.types.d.ts +18 -0
  197. package/lib/scenario/receivers/scenario-receiver.gql.d.ts +8 -0
  198. package/lib/scenario/receivers/scenario-receiver.service.d.ts +30 -0
  199. package/lib/scenario/receivers/scenario-receiver.types.d.ts +54 -0
  200. package/lib/scenario/scenario-setup.service.d.ts +22 -0
  201. package/lib/scenario/scenario.gql.d.ts +34 -0
  202. package/lib/scenario/scenario.service.d.ts +58 -0
  203. package/lib/scenario/scenario.types.d.ts +217 -0
  204. package/lib/search/search.gql.d.ts +1 -0
  205. package/lib/search/search.service.d.ts +25 -0
  206. package/lib/search/search.types.d.ts +20 -0
  207. package/lib/trusted-parties/tp-password-reset-request.service.d.ts +20 -0
  208. package/lib/trusted-parties/tp-password-reset-user.service.d.ts +35 -0
  209. package/lib/trusted-parties/tp-password-reset.constants.d.ts +3 -0
  210. package/lib/trusted-parties/tp-password-reset.gql.d.ts +218 -0
  211. package/lib/trusted-parties/tp-password-reset.service.d.ts +130 -0
  212. package/lib/trusted-parties/trusted-party.gql.d.ts +9 -0
  213. package/lib/trusted-parties/trusted-party.service.d.ts +44 -0
  214. package/lib/trusted-parties/trusted-party.types.d.ts +102 -0
  215. package/lib/trusted-parties/trusted-party2.gql.d.ts +79 -0
  216. package/lib/trusted-parties/trusted-party2.service.d.ts +114 -0
  217. package/lib/users/profile-details.service.d.ts +21 -0
  218. package/lib/users/profile.gql.d.ts +11 -0
  219. package/lib/users/profile.service.d.ts +35 -0
  220. package/lib/users/profile.types.d.ts +96 -0
  221. package/lib/users/user.gql.d.ts +9 -0
  222. package/lib/users/user.service.d.ts +12 -0
  223. package/lib/users/user.types.d.ts +23 -0
  224. package/lifeready-core.d.ts +9 -0
  225. package/lifeready-core.metadata.json +1 -0
  226. package/package.json +29 -21
  227. package/{src/public-api.ts → public-api.d.ts} +77 -96
  228. package/karma.conf.js +0 -32
  229. package/ng-package.json +0 -26
  230. package/src/lib/_common/ast.ts +0 -75
  231. package/src/lib/_common/deferred-promise.ts +0 -35
  232. package/src/lib/_common/exceptions.ts +0 -189
  233. package/src/lib/_common/queries.gql.ts +0 -200
  234. package/src/lib/_common/run-outside-angular.ts +0 -125
  235. package/src/lib/_common/tests.ts +0 -82
  236. package/src/lib/_common/utils.ts +0 -57
  237. package/src/lib/api/api-mutation.spec.ts +0 -547
  238. package/src/lib/api/api-query.spec.ts +0 -40
  239. package/src/lib/api/contact-card.gql.ts +0 -85
  240. package/src/lib/api/contact-card.service.spec.ts +0 -249
  241. package/src/lib/api/contact-card.service.ts +0 -228
  242. package/src/lib/api/contact-card2.gql.ts +0 -93
  243. package/src/lib/api/contact-card2.service.spec.ts +0 -297
  244. package/src/lib/api/contact-card2.service.ts +0 -139
  245. package/src/lib/api/file.service.spec.ts +0 -14
  246. package/src/lib/api/file.service.ts +0 -81
  247. package/src/lib/api/item2.gql.ts +0 -211
  248. package/src/lib/api/item2.service.spec.ts +0 -1043
  249. package/src/lib/api/item2.service.ts +0 -481
  250. package/src/lib/api/key-exchange.gql.ts +0 -196
  251. package/src/lib/api/key-exchange.service.spec.ts +0 -470
  252. package/src/lib/api/key-exchange.service.ts +0 -731
  253. package/src/lib/api/key-exchange.types.ts +0 -235
  254. package/src/lib/api/key-exchange2.gql.ts +0 -310
  255. package/src/lib/api/key-exchange2.service.spec.ts +0 -892
  256. package/src/lib/api/key-exchange2.service.ts +0 -875
  257. package/src/lib/api/lock.gql.ts +0 -67
  258. package/src/lib/api/lock.service.spec.ts +0 -549
  259. package/src/lib/api/lock.service.ts +0 -57
  260. package/src/lib/api/lr-apollo.service.spec.ts +0 -27
  261. package/src/lib/api/lr-apollo.service.ts +0 -43
  262. package/src/lib/api/lr-graphql/lr-graphql.service.ts +0 -313
  263. package/src/lib/api/lr-graphql/lr-merged-mutation.ts +0 -377
  264. package/src/lib/api/lr-graphql/lr-mutation-base.ts +0 -67
  265. package/src/lib/api/lr-graphql/lr-mutation.ts +0 -74
  266. package/src/lib/api/lr-graphql/lr.service.ts +0 -28
  267. package/src/lib/api/message.service.spec.ts +0 -20
  268. package/src/lib/api/message.service.ts +0 -210
  269. package/src/lib/api/persist.service.spec.ts +0 -209
  270. package/src/lib/api/persist.service.ts +0 -220
  271. package/src/lib/api/query-processor/common-processors.service.ts +0 -148
  272. package/src/lib/api/query-processor/query-processor.service.ts +0 -240
  273. package/src/lib/api/query-processor/tp-password-reset-processor.service.ts +0 -177
  274. package/src/lib/api/shared-contact-card.service.ts +0 -156
  275. package/src/lib/api/shared-contact-card2.gql.ts +0 -76
  276. package/src/lib/api/shared-contact-card2.service.ts +0 -154
  277. package/src/lib/api/time.service.spec.ts +0 -48
  278. package/src/lib/api/time.service.ts +0 -155
  279. package/src/lib/api/types/graphql.types.ts +0 -48
  280. package/src/lib/api/types/lr-graphql.types.ts +0 -467
  281. package/src/lib/auth/auth.config.ts +0 -83
  282. package/src/lib/auth/auth.gql.ts +0 -62
  283. package/src/lib/auth/auth.types.ts +0 -79
  284. package/src/lib/auth/idle.service.spec.ts +0 -119
  285. package/src/lib/auth/idle.service.ts +0 -208
  286. package/src/lib/auth/idle.types.ts +0 -11
  287. package/src/lib/auth/lbop.service.spec.ts +0 -56
  288. package/src/lib/auth/lbop.service.ts +0 -539
  289. package/src/lib/auth/life-ready-auth.service.spec.ts +0 -70
  290. package/src/lib/auth/life-ready-auth.service.ts +0 -454
  291. package/src/lib/auth/password.service.spec.ts +0 -51
  292. package/src/lib/auth/password.service.ts +0 -438
  293. package/src/lib/auth/register.service.spec.ts +0 -31
  294. package/src/lib/auth/register.service.ts +0 -181
  295. package/src/lib/auth/two-factor.service.spec.ts +0 -21
  296. package/src/lib/auth/two-factor.service.ts +0 -69
  297. package/src/lib/category/category-meta.service.spec.ts +0 -28
  298. package/src/lib/category/category-meta.service.ts +0 -125
  299. package/src/lib/category/category.gql.ts +0 -449
  300. package/src/lib/category/category.service.spec.ts +0 -26
  301. package/src/lib/category/category.service.ts +0 -498
  302. package/src/lib/category/category.types.ts +0 -89
  303. package/src/lib/cryptography/cryptography.types.ts +0 -108
  304. package/src/lib/cryptography/encryption.service.spec.ts +0 -125
  305. package/src/lib/cryptography/encryption.service.ts +0 -243
  306. package/src/lib/cryptography/key-factory.service.spec.ts +0 -15
  307. package/src/lib/cryptography/key-factory.service.ts +0 -303
  308. package/src/lib/cryptography/key-graph.service.spec.ts +0 -16
  309. package/src/lib/cryptography/key-graph.service.ts +0 -354
  310. package/src/lib/cryptography/key-meta.service.spec.ts +0 -40
  311. package/src/lib/cryptography/key-meta.service.ts +0 -254
  312. package/src/lib/cryptography/key.service.spec.ts +0 -16
  313. package/src/lib/cryptography/key.service.ts +0 -154
  314. package/src/lib/cryptography/slip39.service.spec.ts +0 -44
  315. package/src/lib/cryptography/slip39.service.ts +0 -204
  316. package/src/lib/cryptography/web-crypto.service.ts +0 -22
  317. package/src/lib/life-ready.config.ts +0 -127
  318. package/src/lib/life-ready.module.ts +0 -81
  319. package/src/lib/plan/plan.gql.ts +0 -133
  320. package/src/lib/plan/plan.service.spec.ts +0 -294
  321. package/src/lib/plan/plan.service.ts +0 -198
  322. package/src/lib/plan/plan.types.ts +0 -37
  323. package/src/lib/record/record-attachment.service.spec.ts +0 -31
  324. package/src/lib/record/record-attachment.service.ts +0 -101
  325. package/src/lib/record/record.gql.ts +0 -192
  326. package/src/lib/record/record.service.spec.ts +0 -598
  327. package/src/lib/record/record.service.ts +0 -236
  328. package/src/lib/record/record.types.ts +0 -86
  329. package/src/lib/record-type/record-type.service.spec.ts +0 -16
  330. package/src/lib/record-type/record-type.service.ts +0 -71
  331. package/src/lib/record-type/record-type.types.ts +0 -58
  332. package/src/lib/scenario/approvals/scenario-approval.gql.ts +0 -112
  333. package/src/lib/scenario/approvals/scenario-approval.types.ts +0 -85
  334. package/src/lib/scenario/approvals/scenario-approver.service.spec.ts +0 -16
  335. package/src/lib/scenario/approvals/scenario-approver.service.ts +0 -422
  336. package/src/lib/scenario/claimants/scenario-claimant.gql.ts +0 -56
  337. package/src/lib/scenario/claimants/scenario-claimant.service.spec.ts +0 -16
  338. package/src/lib/scenario/claimants/scenario-claimant.service.ts +0 -100
  339. package/src/lib/scenario/claimants/scenario-claimant.types.ts +0 -21
  340. package/src/lib/scenario/receivers/scenario-receiver.gql.ts +0 -157
  341. package/src/lib/scenario/receivers/scenario-receiver.service.spec.ts +0 -16
  342. package/src/lib/scenario/receivers/scenario-receiver.service.ts +0 -278
  343. package/src/lib/scenario/receivers/scenario-receiver.types.ts +0 -66
  344. package/src/lib/scenario/scenario-setup.service.spec.ts +0 -22
  345. package/src/lib/scenario/scenario-setup.service.ts +0 -369
  346. package/src/lib/scenario/scenario.gql.ts +0 -404
  347. package/src/lib/scenario/scenario.service.spec.ts +0 -1586
  348. package/src/lib/scenario/scenario.service.ts +0 -811
  349. package/src/lib/scenario/scenario.types.ts +0 -258
  350. package/src/lib/search/search.gql.ts +0 -62
  351. package/src/lib/search/search.service.spec.ts +0 -57
  352. package/src/lib/search/search.service.ts +0 -174
  353. package/src/lib/search/search.types.ts +0 -24
  354. package/src/lib/trusted-parties/tp-password-reset-request.service.ts +0 -140
  355. package/src/lib/trusted-parties/tp-password-reset-user.service.ts +0 -359
  356. package/src/lib/trusted-parties/tp-password-reset.gql.ts +0 -453
  357. package/src/lib/trusted-parties/tp-password-reset.service.spec.ts +0 -602
  358. package/src/lib/trusted-parties/tp-password-reset.service.ts +0 -482
  359. package/src/lib/trusted-parties/trusted-party.gql.ts +0 -159
  360. package/src/lib/trusted-parties/trusted-party.service.spec.ts +0 -1008
  361. package/src/lib/trusted-parties/trusted-party.service.ts +0 -394
  362. package/src/lib/trusted-parties/trusted-party.types.ts +0 -119
  363. package/src/lib/trusted-parties/trusted-party2.gql.ts +0 -165
  364. package/src/lib/trusted-parties/trusted-party2.service.spec.ts +0 -1782
  365. package/src/lib/trusted-parties/trusted-party2.service.ts +0 -272
  366. package/src/lib/users/profile-details.service.spec.ts +0 -45
  367. package/src/lib/users/profile-details.service.ts +0 -278
  368. package/src/lib/users/profile.gql.ts +0 -108
  369. package/src/lib/users/profile.service.spec.ts +0 -97
  370. package/src/lib/users/profile.service.ts +0 -224
  371. package/src/lib/users/profile.types.ts +0 -101
  372. package/src/lib/users/user.gql.ts +0 -69
  373. package/src/lib/users/user.service.spec.ts +0 -161
  374. package/src/lib/users/user.service.ts +0 -72
  375. package/src/lib/users/user.types.ts +0 -27
  376. package/src/test.ts +0 -21
  377. package/tsconfig.lib.json +0 -21
  378. package/tsconfig.lib.prod.json +0 -6
  379. package/tsconfig.spec.json +0 -10
  380. package/tslint.json +0 -17
@@ -0,0 +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":"/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"]}