@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,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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NlbmFyaW8tYXBwcm92ZXIuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIvb3B0L2F0bGFzc2lhbi9waXBlbGluZXMvYWdlbnQvYnVpbGQvcHJvamVjdHMvY29yZS9zcmMvIiwic291cmNlcyI6WyJsaWIvc2NlbmFyaW8vYXBwcm92YWxzL3NjZW5hcmlvLWFwcHJvdmVyLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFM0MsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQzlELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQzFFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHdDQUF3QyxDQUFDO0FBQzNFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQztBQUN2RSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFDckUsT0FBTyxLQUFLLElBQUksTUFBTSxtQ0FBbUMsQ0FBQztBQUMxRCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSw2Q0FBNkMsQ0FBQztBQU9sRixPQUFPLEVBQ0wsc0NBQXNDLEVBQ3RDLHNDQUFzQyxFQUN0Qyx3QkFBd0IsRUFDeEIsc0NBQXNDLEVBQ3RDLDhCQUE4QixHQUMvQixNQUFNLHlCQUF5QixDQUFDOzs7Ozs7Ozs7QUFhakMsTUFBTSxPQUFPLHVCQUF1QjtJQUdsQyxZQUNVLFFBQXlCLEVBQ3pCLFVBQTZCLEVBQzdCLGNBQThCLEVBQzlCLFFBQXlCLEVBQ3pCLGFBQWlDLEVBQ2pDLGlCQUFvQyxFQUNwQyxtQkFBd0M7UUFOeEMsYUFBUSxHQUFSLFFBQVEsQ0FBaUI7UUFDekIsZUFBVSxHQUFWLFVBQVUsQ0FBbUI7UUFDN0IsbUJBQWMsR0FBZCxjQUFjLENBQWdCO1FBQzlCLGFBQVEsR0FBUixRQUFRLENBQWlCO1FBQ3pCLGtCQUFhLEdBQWIsYUFBYSxDQUFvQjtRQUNqQyxzQkFBaUIsR0FBakIsaUJBQWlCLENBQW1CO1FBQ3BDLHdCQUFtQixHQUFuQixtQkFBbUIsQ0FBcUI7SUFDL0MsQ0FBQztJQUVTLFdBQVcsQ0FBQyxVQUFrQjs7WUFDekMsTUFBTSxFQUFFLGdCQUFnQixFQUFFLEdBQUcsTUFBTSxJQUFJLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBTTtnQkFDMUQsS0FBSyxFQUFFLHdCQUF3QjtnQkFDL0IsU0FBUyxFQUFFO29CQUNULEVBQUUsRUFBRSxVQUFVO2lCQUNmO2FBQ0YsQ0FBQyxDQUFDO1lBQ0gsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDLGdCQUFnQixDQUFDLENBQUM7UUFDNUMsQ0FBQztLQUFBO0lBRVksZ0JBQWdCLENBQUMsS0FBVTs7WUFDdEMsTUFBTSxFQUFFLElBQUksRUFBRSxHQUFHLE1BQU0sSUFBSSxDQUFDLFFBQVEsQ0FBQyxpQkFBaUIsQ0FFbkQsS0FBSyxDQUFDLFdBQVcsQ0FBQyxFQUFFLEVBQUUsS0FBSyxDQUFDLHFCQUFxQixDQUFDLENBQUM7WUFFdEQsT0FBTztnQkFDTCxFQUFFLEVBQUUsS0FBSyxDQUFDLEVBQUU7Z0JBQ1osS0FBSyxFQUFFLEtBQUssQ0FBQyxXQUFXLENBQUMsRUFBRTtnQkFDM0IsSUFBSTtnQkFDSixNQUFNLEVBQUUsS0FBSyxDQUFDLE1BQU07Z0JBQ3BCLFlBQVksRUFBRSxLQUFLLENBQUMsWUFBWTtnQkFDaEMsU0FBUyxFQUFFLE1BQU0sT0FBTyxDQUFDLEdBQUcsQ0FDMUIsS0FBSyxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUMzRDthQUNGLENBQUM7UUFDSixDQUFDO0tBQUE7SUFFYSxXQUFXLENBQUMsUUFBYTs7WUFDckMsTUFBTSxFQUFFLE9BQU8sRUFBRSxHQUFHLE1BQU0sSUFBSSxDQUFDLFFBQVEsQ0FBQyxpQkFBaUIsQ0FFdEQsUUFBUSxDQUFDLFNBQVMsQ0FBQyxFQUFFLEVBQUUsUUFBUSxDQUFDLGdCQUFnQixDQUFDLENBQUM7WUFFckQsT0FBTztnQkFDTCxFQUFFLEVBQUUsUUFBUSxDQUFDLEVBQUU7Z0JBQ2YsS0FBSyxFQUFFLFFBQVEsQ0FBQyxTQUFTLENBQUMsRUFBRTtnQkFDNUIsWUFBWSxFQUFFLE1BQU0sSUFBSSxDQUFDLG1CQUFtQixDQUFDLGVBQWUsQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDO2dCQUN6RSxPQUFPO2FBQ1IsQ0FBQztRQUNKLENBQUM7S0FBQTtJQUVZLGNBQWMsQ0FBQyxRQUFnQzs7WUFDMUQsTUFBTSxnQkFBZ0IsR0FBRyxNQUFNLElBQUksQ0FBQyxRQUFRLENBQUMsZUFBZSxDQUMxRCxRQUFRLENBQUMsS0FBSyxFQUNkLFFBQVEsQ0FBQyxxQkFBcUIsQ0FDL0IsQ0FBQztZQUVGLE1BQU0sSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQU07Z0JBQzlCLFFBQVEsRUFBRSw4QkFBOEI7Z0JBQ3hDLFNBQVMsRUFBRTtvQkFDVCxLQUFLLEVBQUU7d0JBQ0wsVUFBVSxFQUFFLFFBQVEsQ0FBQyxVQUFVO3dCQUMvQixXQUFXLEVBQUUsUUFBUSxDQUFDLEtBQUs7d0JBQzNCLGdCQUFnQjt3QkFDaEIsd0JBQXdCLEVBQUUsRUFBRTtxQkFDN0I7aUJBQ0Y7YUFDRixDQUFDLENBQUM7UUFDTCxDQUFDO0tBQUE7SUFFWSw4QkFBOEIsQ0FDekMsS0FBbUM7O1lBRW5DLE1BQU0sV0FBVyxHQUFHLE1BQU0sSUFBSSxDQUFDLFVBQVUsQ0FBQyxTQUFTLEVBQUUsQ0FBQztZQUV0RCxNQUFNLDRCQUE0QixHQUFHLE1BQU0sSUFBSSxDQUFDLFFBQVEsQ0FBQyxlQUFlLENBQ3RFLEtBQUssQ0FBQyxLQUFLLEVBQ1gsV0FBVyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FDekIsQ0FBQztZQUVGLE1BQU0sa0JBQWtCLEdBQUcsS0FBSyxDQUFDLHVCQUF1QjtnQkFDdEQsQ0FBQyxDQUFDLE1BQU0sSUFBSSxDQUFDLFFBQVEsQ0FBQyxlQUFlLENBQ2pDLFdBQVcsRUFDWCxLQUFLLENBQUMsdUJBQXVCLENBQzlCO2dCQUNILENBQUMsQ0FBQyxFQUFFLENBQUM7WUFFUCxNQUFNLEVBQUUsOEJBQThCLEVBQUUsR0FBRyxNQUFNLElBQUksQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFNO2dCQUN6RSxRQUFRLEVBQUUsc0NBQXNDO2dCQUNoRCxTQUFTLEVBQUU7b0JBQ1QsS0FBSyxFQUFFO3dCQUNMLFVBQVUsRUFBRSxLQUFLLENBQUMsVUFBVTt3QkFDNUIsWUFBWSxFQUFFLEtBQUssQ0FBQyxZQUFZO3dCQUNoQyxNQUFNLEVBQUUsS0FBSyxDQUFDLE1BQU07d0JBQ3BCLFlBQVksRUFBRSxLQUFLLENBQUMsS0FBSzt3QkFDekIsNEJBQTRCO3dCQUM1QixrQkFBa0I7d0JBQ2xCLG1CQUFtQixFQUFFLENBQ25CLE1BQU0sSUFBSSxDQUFDLGlCQUFpQixDQUMxQixLQUFLLENBQUMsY0FBYyxFQUNwQixLQUFLLENBQUMsTUFBTSxFQUNaLFdBQVcsQ0FDWixDQUNGLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUU7NEJBQ1YsTUFBTSxFQUFFLGVBQWUsRUFBRSxlQUFlLEtBQXFCLENBQUMsRUFBakIsV0FBVyxVQUFLLENBQUMsRUFBeEQsc0NBQW9ELENBQUksQ0FBQzs0QkFDL0QsT0FBTyxXQUFXLENBQUM7d0JBQ3JCLENBQUMsQ0FBQzt3QkFDRixlQUFlLEVBQUUsTUFBTSxJQUFJLENBQUMsZUFBZSxDQUN6QyxXQUFXLEVBQ1gsS0FBSyxDQUFDLEtBQUssRUFDWCxLQUFLLENBQUMsU0FBUyxDQUNoQjtxQkFDRjtpQkFDRjthQUNGLENBQUMsQ0FBQztZQUNILE9BQU8sOEJBQThCLENBQUMsUUFBUSxDQUFDLGdCQUFnQixDQUFDLFdBQVc7aUJBQ3hFLEVBQUUsQ0FBQztRQUNSLENBQUM7S0FBQTtJQUVZLDhCQUE4QixDQUN6QyxLQUFtQzs7WUFFbkMsTUFBTSxXQUFXLEdBQUcsTUFBTSxJQUFJLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsYUFBYSxDQUFDLENBQUM7WUFDcEUsTUFBTSxrQkFBa0IsR0FBRyxLQUFLLENBQUMsdUJBQXVCO2dCQUN0RCxDQUFDLENBQUMsTUFBTSxJQUFJLENBQUMsUUFBUSxDQUFDLGVBQWUsQ0FDakMsV0FBVyxDQUFDLEdBQUcsRUFDZixLQUFLLENBQUMsdUJBQXVCLENBQzlCO2dCQUNILENBQUMsQ0FBQyxFQUFFLENBQUM7WUFFUCxNQUFNLGNBQWMsR0FBRyxNQUFNLElBQUksQ0FBQyxpQkFBaUIsQ0FDakQsS0FBSyxDQUFDLGNBQWMsRUFDcEIsS0FBSyxDQUFDLE1BQU0sRUFDWixXQUFXLENBQUMsR0FBRyxDQUNoQixDQUFDO1lBRUYsTUFBTSxJQUFJLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBTTtnQkFDOUIsUUFBUSxFQUFFLHNDQUFzQztnQkFDaEQsU0FBUyxFQUFFO29CQUNULEtBQUssRUFBRTt3QkFDTCxVQUFVLEVBQUUsS0FBSyxDQUFDLFVBQVU7d0JBQzVCLFlBQVksRUFBRSxLQUFLLENBQUMsWUFBWTt3QkFDaEMsTUFBTSxFQUFFLEtBQUssQ0FBQyxNQUFNO3dCQUNwQixhQUFhLEVBQUUsV0FBVyxDQUFDLEVBQUU7d0JBQzdCLGtCQUFrQjt3QkFDbEIsbUJBQW1CLEVBQUUsY0FBYzs2QkFDaEMsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxhQUFhLENBQUM7NkJBQy9CLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFOzRCQUNULE1BQU0sRUFBRSxlQUFlLEVBQUUsZUFBZSxLQUFxQixDQUFDLEVBQWpCLFdBQVcsVUFBSyxDQUFDLEVBQXhELHNDQUFvRCxDQUFJLENBQUM7NEJBQy9ELE9BQU8sV0FBVyxDQUFDO3dCQUNyQixDQUFDLENBQUM7d0JBQ0osbUJBQW1CLEVBQUUsY0FBYyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLGFBQWEsQ0FBQzt3QkFDbEUsbUJBQW1CLEVBQUUsS0FBSyxDQUFDLGVBQWU7cUJBQzNDO2lCQUNGO2FBQ0YsQ0FBQyxDQUFDO1FBQ0wsQ0FBQztLQUFBO0lBRVksOEJBQThCLENBQ3pDLFVBQWtCLEVBQ2xCLEtBQWEsRUFDYixTQUFxQjs7WUFFckIsTUFBTSxJQUFJLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBTTtnQkFDOUIsUUFBUSxFQUFFLHNDQUFzQztnQkFDaEQsU0FBUyxFQUFFO29CQUNULEtBQUssRUFBRTt3QkFDTCxVQUFVO3dCQUNWLGVBQWUsRUFBRSxNQUFNLElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxFQUFFLEtBQUssRUFBRSxTQUFTLENBQUM7cUJBQ3BFO2lCQUNGO2FBQ0YsQ0FBQyxDQUFDO1FBQ0wsQ0FBQztLQUFBO0lBRWEsZUFBZSxDQUMzQixXQUFvQixFQUNwQixLQUFhLEVBQ2IsU0FBcUI7O1lBRXJCLElBQUksQ0FBQyxTQUFTLElBQUksQ0FBQyxTQUFTLENBQUMsTUFBTSxFQUFFO2dCQUNuQyxPQUFPLEVBQUUsQ0FBQzthQUNYO1lBRUQsT0FBTyxNQUFNLE9BQU8sQ0FBQyxHQUFHLENBQ3RCLFNBQVMsQ0FBQyxHQUFHLENBQUMsQ0FBTyxRQUFRLEVBQUUsRUFBRTtnQkFDL0IsTUFBTSxTQUFTLEdBQUcsTUFBTSxJQUFJLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUM7Z0JBRTdELE1BQU0sbUJBQW1CLEdBQUcsQ0FDMUIsSUFBdUMsRUFDdkMsU0FBaUIsRUFDakIsRUFBRTtvQkFDRixNQUFNLE9BQU8sR0FBRyxNQUFNLElBQUksQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxDQUFDO29CQUN0RCxJQUFJLGNBQWMsR0FBRyxNQUFNLElBQUksQ0FBQyxRQUFRLENBQUMsZUFBZSxDQUN0RCxTQUFTLENBQUMsR0FBRyxFQUNiLE9BQU8sQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUN6QixDQUFDO29CQUVGLElBQUksV0FBVyxFQUFFO3dCQUNmLGNBQWMsR0FBRyxNQUFNLElBQUksQ0FBQyxRQUFRLENBQUMsZUFBZSxDQUNsRCxXQUFXLEVBQ1gsY0FBYyxDQUNmLENBQUM7cUJBQ0g7b0JBRUQsT0FBTzt3QkFDTCxVQUFVLEVBQUUsSUFBSSxDQUFDLFdBQVc7d0JBQzVCLFdBQVcsRUFBRSxTQUFTLENBQUMsRUFBRTt3QkFDekIsZ0JBQWdCLEVBQUUsRUFBRTt3QkFDcEIsY0FBYztxQkFDZixDQUFDO2dCQUNKLENBQUMsQ0FBQSxDQUFDO2dCQUVGLDhCQUE4QjtnQkFDOUIsTUFBTSxtQkFBbUIsR0FBRyxNQUFNLE9BQU8sQ0FBQyxHQUFHLENBQUM7b0JBQzVDLEdBQUcsUUFBUSxDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQUMsQ0FBTyxDQUFDLEVBQUUsRUFBRTt3QkFBQyxPQUFBLGlDQUNuQyxDQUFDLE1BQU0sbUJBQW1CLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUMsS0FDbkQsbUJBQW1CLEVBQUUsQ0FBQyxDQUFDLEVBQUUsSUFDekIsQ0FBQTtzQkFBQSxDQUFDO29CQUNILEdBQUcsUUFBUSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBTyxDQUFDLEVBQUUsRUFBRTt3QkFBQyxPQUFBLGlDQUNoQyxDQUFDLE1BQU0sbUJBQW1CLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUMsS0FDakQsbUJBQW1CLEVBQUUsQ0FBQyxDQUFDLEVBQUUsSUFDekIsQ0FBQTtzQkFBQSxDQUFDO2lCQUNKLENBQUMsQ0FBQztnQkFFSCxPQUFPO29CQUNMLFVBQVUsRUFBRSxRQUFRLENBQUMsRUFBRTtvQkFDdkIsV0FBVyxFQUFFLFFBQVEsQ0FBQyxLQUFLO29CQUMzQixtQkFBbUI7b0JBQ25CLGFBQWEsRUFBRSxFQUFFO29CQUNqQixnQkFBZ0IsRUFBRSxNQUFNLElBQUksQ0FBQyxRQUFRLENBQUMsZUFBZSxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUU7d0JBQ25FLEtBQUs7d0JBQ0wsT0FBTyxFQUFFLFFBQVEsQ0FBQyxPQUFPO3FCQUMxQixDQUFDO2lCQUNILENBQUM7WUFDSixDQUFDLENBQUEsQ0FBQyxDQUNILENBQUM7UUFDSixDQUFDO0tBQUE7SUFFYSxpQkFBaUIsQ0FDN0IsY0FBNkMsRUFDN0MsTUFBYyxFQUNkLFdBQW9COztZQUVwQixNQUFNLFlBQVksR0FBRyxNQUFNLElBQUksQ0FBQyxrQkFBa0IsQ0FDaEQsTUFBTSxFQUNOLGNBQWMsRUFDYixXQUFXLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBUyxDQUFDLENBQUMsQ0FDcEMsQ0FBQztZQUNGLE9BQU8sTUFBTSxPQUFPLENBQUMsR0FBRyxDQUN0QixjQUFjLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEtBQUssRUFBRSxFQUFFLENBQzlCLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLEVBQUUsWUFBWSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsRUFBRSxXQUFXLENBQUMsQ0FDekUsQ0FDRixDQUFDO1FBQ0osQ0FBQztLQUFBO0lBRWEsZ0JBQWdCLENBQzVCLGFBQTBDLEVBQzFDLFdBQTZCLEVBQzdCLFdBQW9COztZQUVwQixNQUFNLFNBQVMsR0FBRyxNQUFNLElBQUksQ0FBQyxZQUFZLENBQ3ZDLGFBQWEsQ0FBQyxTQUFTLEVBQ3ZCLGFBQWEsQ0FBQyxNQUFNLEVBQ3BCLFdBQVcsRUFDWCxXQUFXLENBQ1osQ0FBQztZQUVGLE9BQU87Z0JBQ0wsYUFBYSxFQUFFLGFBQWEsQ0FBQyxhQUFhO2dCQUMxQyxZQUFZLEVBQUUsYUFBYSxDQUFDLFlBQVk7Z0JBQ3hDLE1BQU0sRUFBRSxhQUFhLENBQUMsTUFBTTtnQkFDNUIscUJBQXFCLEVBQUUsTUFBTSxJQUFJLENBQUMsUUFBUSxDQUFDLGVBQWUsQ0FDeEQsV0FBVyxFQUNYLGFBQWEsQ0FBQywwQkFBMEIsQ0FDekM7Z0JBQ0QsZUFBZSxFQUFFLFNBQVMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLFVBQVUsQ0FBQztnQkFDdkQsZUFBZSxFQUFFLFNBQVMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxVQUFVLENBQUM7Z0JBQ3RELGVBQWUsRUFBRSxhQUFhLENBQUMsa0JBQWtCLElBQUksRUFBRTthQUN4RCxDQUFDO1FBQ0osQ0FBQztLQUFBO0lBRWEsWUFBWSxDQUN4QixTQUFtQyxFQUNuQyxNQUFjLEVBQ2QsV0FBNkIsRUFDN0IsV0FBb0I7O1lBRXBCLE1BQU0sS0FBOEMsV0FBVyxDQUFDLE1BQU0sQ0FDcEUsSUFBSSxDQUNFLEVBRkYsRUFBRSxDQUFDLEVBQUUsY0FBYyxPQUVqQixFQUZzQixpQkFBaUIsY0FBekMsS0FBMkMsQ0FFekMsQ0FBQztZQUNULElBQUksUUFBUSxHQUFHLENBQUMsQ0FBQztZQUVqQixNQUFNLHNCQUFzQixHQUFHLENBQU8sWUFBcUIsRUFBRSxFQUFFO2dCQUM3RCxNQUFNLEtBQUssR0FBRyxXQUFXLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDO2dCQUMzQyw4REFBOEQ7Z0JBQzlELElBQUksTUFBTSxLQUFLLENBQUMsRUFBRTtvQkFDaEIsRUFBRSxRQUFRLENBQUM7aUJBQ1o7Z0JBQ0QsTUFBTSxrQkFBa0IsR0FBdUI7b0JBQzdDLE1BQU0sRUFBRTt3QkFDTixLQUFLO3dCQUNMLFdBQVcsRUFBRTs0QkFDWCxNQUFNOzRCQUNOLElBQUksRUFBRSxTQUFTLENBQUMsTUFBTTt5QkFDdkI7cUJBQ0Y7b0JBQ0QsaUJBQWlCO2lCQUNsQixDQUFDO2dCQUNGLE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQyxlQUFlLENBQUMsWUFBWSxFQUFFLGtCQUFrQixDQUFDLENBQUM7WUFDekUsQ0FBQyxDQUFBLENBQUM7WUFFRixPQUFPLE1BQU0sT0FBTyxDQUFDLEdBQUcsQ0FDdEIsU0FBUyxDQUFDLEdBQUcsQ0FBQyxDQUFPLENBQUMsRUFBRSxFQUFFO2dCQUN4QixJQUFJLENBQUMsQ0FBQyxVQUFVLEVBQUU7b0JBQ2hCLE1BQU0sU0FBUyxHQUFHLE1BQU0sSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDO29CQUN0RCxNQUFNLGdCQUFnQixHQUFHLE1BQU0sSUFBSSxDQUFDLFFBQVEsQ0FBQyxlQUFlLENBQzFELENBQUMsQ0FBQyxLQUFLLEVBQ1AsQ0FBQyxDQUFDLHFCQUFxQixDQUN4QixDQUFDO29CQUNGLE1BQU0sd0JBQXdCLEdBQUcsTUFBTSxJQUFJLENBQUMsUUFBUSxDQUFDLGVBQWUsQ0FDbEUsQ0FBQyxDQUFDLEtBQUssRUFDUCxDQUFDLENBQUMsWUFBWSxDQUNmLENBQUM7b0JBRUYsT0FBTzt3QkFDTCxVQUFVLEVBQUUsQ0FBQyxDQUFDLFVBQVU7d0JBQ3hCLFdBQVcsRUFBRSxDQUFDLENBQUMsS0FBSzt3QkFDcEIsZ0JBQWdCLEVBQUUsZ0JBQWdCLElBQUksRUFBRTt3QkFDeEMsd0JBQXdCLEVBQUUsd0JBQXdCLElBQUksRUFBRTt3QkFDeEQsOEJBQThCLEVBQUUsTUFBTSxzQkFBc0IsQ0FDMUQsU0FBUyxDQUFDLEdBQUcsQ0FDZDtxQkFDRixDQUFDO2lCQUNIO3FCQUFNO29CQUNMLE1BQU0sY0FBYyxHQUFHLE1BQU0sSUFBSSxDQUFDLGNBQWMsQ0FBQyxrQkFBa0IsQ0FDakUsQ0FBQyxDQUFDLHFCQUFxQixFQUN2QixDQUFDLENBQUMsdUJBQXVCLENBQzFCLENBQUM7b0JBRUYsT0FBTzt3QkFDTCxJQUFJLEVBQUUsQ0FBQyxDQUFDLGNBQWM7d0JBQ3RCLGFBQWEsRUFBRSxDQUFDLENBQUMsdUJBQXVCO3dCQUN4QywyQkFBMkIsRUFBRSxjQUFjLENBQUMsT0FBTyxDQUFDLFVBQVU7d0JBQzlELGdCQUFnQixFQUFFLGNBQWMsQ0FBQyxVQUFVO3dCQUMzQyx3QkFBd0IsRUFBRSxFQUFFO3dCQUM1Qiw4QkFBOEIsRUFBRSxNQUFNLHNCQUFzQixDQUMxRCxjQUFjLENBQUMsR0FBRyxDQUNuQjtxQkFDRixDQUFDO2lCQUNIO1lBQ0gsQ0FBQyxDQUFBLENBQUMsQ0FDSCxDQUFDO1FBQ0osQ0FBQztLQUFBO0lBRUQscURBQXFEO0lBQ3ZDLGtCQUFrQixDQUM5QixNQUFjLEVBQ2QsY0FBNkMsRUFDN0MsY0FBc0I7O1lBRXRCLE1BQU0sWUFBWSxHQUFHLElBQUksSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUUvQyxjQUFjLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxFQUFFLEtBQUssRUFBRSxFQUFFO2dCQUNsQyxJQUFJLGFBQWEsR0FBRyxDQUFDLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQztnQkFFdkMsZ0ZBQWdGO2dCQUNoRiw0Q0FBNEM7Z0JBQzVDLElBQUksQ0FBQyxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7b0JBQ2xCLGFBQWEsR0FBRyxDQUFDLENBQUM7aUJBQ25CO2dCQUNELFlBQVksQ0FBQyxjQUFjLENBQ3pCLElBQUksSUFBSSxDQUFDLFdBQVcsQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDLE1BQU0sRUFBRSxhQUFhLENBQUMsQ0FDckQsQ0FBQztZQUNKLENBQUMsQ0FBQyxDQUFDO1lBQ0gsZ0RBQWdEO1lBQ2hELElBQUksWUFBWSxDQUFDLGFBQWEsQ0FBQyxNQUFNLEdBQUcsTUFBTSxFQUFFO2dCQUM5QyxPQUFPLElBQUksQ0FBQzthQUNiO1lBQ0QsTUFBTSxJQUFJLENBQUMsYUFBYSxDQUFDLGNBQWMsQ0FDckMsY0FBYyxFQUNkLHVCQUF1QixDQUFDLGlCQUFpQixFQUN6QyxZQUFZLENBQ2IsQ0FBQztZQUNGLE9BQU8sWUFBWSxDQUFDO1FBQ3RCLENBQUM7S0FBQTs7QUFqWWEseUNBQWlCLEdBQUcsV0FBVyxDQUFDOzs7WUFKL0MsVUFBVSxTQUFDO2dCQUNWLFVBQVUsRUFBRSxNQUFNO2FBQ25COzs7WUEvQlEsZUFBZTtZQUVmLGlCQUFpQjtZQUVqQixjQUFjO1lBRGQsZUFBZTtZQUVaLElBQUksQ0FtQ2dCLGFBQWE7WUF2Q3BDLGlCQUFpQjtZQUtqQixtQkFBbUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBKV0sgfSBmcm9tICdub2RlLWpvc2UnO1xuaW1wb3J0IHsgTHJBcG9sbG9TZXJ2aWNlIH0gZnJvbSAnLi4vLi4vYXBpL2xyLWFwb2xsby5zZXJ2aWNlJztcbmltcG9ydCB7IEVuY3J5cHRpb25TZXJ2aWNlIH0gZnJvbSAnLi4vLi4vY3J5cHRvZ3JhcGh5L2VuY3J5cHRpb24uc2VydmljZSc7XG5pbXBvcnQgeyBLZXlGYWN0b3J5U2VydmljZSB9IGZyb20gJy4uLy4uL2NyeXB0b2dyYXBoeS9rZXktZmFjdG9yeS5zZXJ2aWNlJztcbmltcG9ydCB7IEtleUdyYXBoU2VydmljZSB9IGZyb20gJy4uLy4uL2NyeXB0b2dyYXBoeS9rZXktZ3JhcGguc2VydmljZSc7XG5pbXBvcnQgeyBLZXlNZXRhU2VydmljZSB9IGZyb20gJy4uLy4uL2NyeXB0b2dyYXBoeS9rZXktbWV0YS5zZXJ2aWNlJztcbmltcG9ydCAqIGFzIHNsaXAgZnJvbSAnLi4vLi4vY3J5cHRvZ3JhcGh5L3NsaXAzOS5zZXJ2aWNlJztcbmltcG9ydCB7IFRydXN0ZWRQYXJ0eVNlcnZpY2UgfSBmcm9tICcuLi8uLi90cnVzdGVkLXBhcnRpZXMvdHJ1c3RlZC1wYXJ0eS5zZXJ2aWNlJztcbmltcG9ydCB7XG4gIFJlY2VpdmVyLFxuICBSZWNlaXZlckNhdGVnb3J5LFxuICBSZWNlaXZlclJlY29yZCxcbn0gZnJvbSAnLi4vcmVjZWl2ZXJzL3NjZW5hcmlvLXJlY2VpdmVyLnR5cGVzJztcbmltcG9ydCB7IFBhcnRpYWxBc3NlbWJseUtleSB9IGZyb20gJy4uL3NjZW5hcmlvLnR5cGVzJztcbmltcG9ydCB7XG4gIENyZWF0ZVNjZW5hcmlvQXBwcm92ZXJBc3NlbWJseU11dGF0aW9uLFxuICBEZWxldGVTY2VuYXJpb0FwcHJvdmVyQXNzZW1ibHlNdXRhdGlvbixcbiAgR2V0U2NlbmFyaW9BcHByb3ZlclF1ZXJ5LFxuICBVcGRhdGVTY2VuYXJpb0FwcHJvdmVyQXNzZW1ibHlNdXRhdGlvbixcbiAgVXBkYXRlU2NlbmFyaW9BcHByb3Zlck11dGF0aW9uLFxufSBmcm9tICcuL3NjZW5hcmlvLWFwcHJvdmFsLmdxbCc7XG5pbXBvcnQge1xuICBBcHByb3ZhbEdyb3VwLFxuICBBcHByb3ZlcixcbiAgQ3JlYXRlU2NlbmFyaW9BcHByb3ZhbEdyb3VwcyxcbiAgVXBkYXRlU2NlbmFyaW9BcHByb3ZhbEdyb3VwLFxuICBVcGRhdGVTY2VuYXJpb0FwcHJvdmFsR3JvdXBzLFxuICBVcGRhdGVTY2VuYXJpb0FwcHJvdmVyLFxufSBmcm9tICcuL3NjZW5hcmlvLWFwcHJvdmFsLnR5cGVzJztcblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCcsXG59KVxuZXhwb3J0IGNsYXNzIFNjZW5hcmlvQXBwcm92ZXJTZXJ2aWNlIHtcbiAgcHVibGljIHN0YXRpYyBTTElQMzlfUEFTU1BIUkFTRSA9ICdsaWZlcmVhZHknO1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHByaXZhdGUgbHJBcG9sbG86IExyQXBvbGxvU2VydmljZSxcbiAgICBwcml2YXRlIGtleUZhY3Rvcnk6IEtleUZhY3RvcnlTZXJ2aWNlLFxuICAgIHByaXZhdGUga2V5TWV0YVNlcnZpY2U6IEtleU1ldGFTZXJ2aWNlLFxuICAgIHByaXZhdGUga2V5R3JhcGg6IEtleUdyYXBoU2VydmljZSxcbiAgICBwcml2YXRlIHNsaXAzOVNlcnZpY2U6IHNsaXAuU2xpcDM5U2VydmljZSxcbiAgICBwcml2YXRlIGVuY3J5cHRpb25TZXJ2aWNlOiBFbmNyeXB0aW9uU2VydmljZSxcbiAgICBwcml2YXRlIHRydXN0ZWRQYXJ0eVNlcnZpY2U6IFRydXN0ZWRQYXJ0eVNlcnZpY2VcbiAgKSB7fVxuXG4gIHB1YmxpYyBhc3luYyBnZXRBcHByb3ZlcihhcHByb3ZlcklkOiBzdHJpbmcpOiBQcm9taXNlPEFwcHJvdmVyPiB7XG4gICAgY29uc3QgeyBzY2VuYXJpb0FwcHJvdmVyIH0gPSBhd2FpdCB0aGlzLmxyQXBvbGxvLnF1ZXJ5PGFueT4oe1xuICAgICAgcXVlcnk6IEdldFNjZW5hcmlvQXBwcm92ZXJRdWVyeSxcbiAgICAgIHZhcmlhYmxlczoge1xuICAgICAgICBpZDogYXBwcm92ZXJJZCxcbiAgICAgIH0sXG4gICAgfSk7XG4gICAgcmV0dXJuIHRoaXMubWFwQXBwcm92ZXIoc2NlbmFyaW9BcHByb3Zlcik7XG4gIH1cblxuICBwdWJsaWMgYXN5bmMgbWFwQXBwcm92ZXJHcm91cChncm91cDogYW55KTogUHJvbWlzZTxBcHByb3ZhbEdyb3VwPiB7XG4gICAgY29uc3QgeyBuYW1lIH0gPSBhd2FpdCB0aGlzLmtleUdyYXBoLmRlY3J5cHRGcm9tU3RyaW5nPHtcbiAgICAgIG5hbWU6IHN0cmluZztcbiAgICB9Pihncm91cC5hc3NlbWJseUtleS5pZCwgZ3JvdXAuc3ViQXNzZW1ibHlDaXBoZXJEYXRhKTtcblxuICAgIHJldHVybiB7XG4gICAgICBpZDogZ3JvdXAuaWQsXG4gICAgICBrZXlJZDogZ3JvdXAuYXNzZW1ibHlLZXkuaWQsXG4gICAgICBuYW1lLFxuICAgICAgcXVvcnVtOiBncm91cC5xdW9ydW0sXG4gICAgICBzaW5nbGVSZWplY3Q6IGdyb3VwLnNpbmdsZVJlamVjdCxcbiAgICAgIGFwcHJvdmVyczogYXdhaXQgUHJvbWlzZS5hbGwoXG4gICAgICAgIGdyb3VwLmFwcHJvdmVycy5lZGdlcy5tYXAoKHgpID0+IHRoaXMubWFwQXBwcm92ZXIoeC5ub2RlKSlcbiAgICAgICksXG4gICAgfTtcbiAgfVxuXG4gIHByaXZhdGUgYXN5bmMgbWFwQXBwcm92ZXIoYXBwcm92ZXI6IGFueSk6IFByb21pc2U8QXBwcm92ZXI+IHtcbiAgICBjb25zdCB7IG1lc3NhZ2UgfSA9IGF3YWl0IHRoaXMua2V5R3JhcGguZGVjcnlwdEZyb21TdHJpbmc8e1xuICAgICAgbWVzc2FnZTogc3RyaW5nO1xuICAgIH0+KGFwcHJvdmVyLnNoYXJlZEtleS5pZCwgYXBwcm92ZXIuc2hhcmVkQ2lwaGVyRGF0YSk7XG5cbiAgICByZXR1cm4ge1xuICAgICAgaWQ6IGFwcHJvdmVyLmlkLFxuICAgICAga2V5SWQ6IGFwcHJvdmVyLnNoYXJlZEtleS5pZCxcbiAgICAgIHRydXN0ZWRQYXJ0eTogYXdhaXQgdGhpcy50cnVzdGVkUGFydHlTZXJ2aWNlLm1hcFRydXN0ZWRQYXJ0eShhcHByb3Zlci50cCksXG4gICAgICBtZXNzYWdlLFxuICAgIH07XG4gIH1cblxuICBwdWJsaWMgYXN5bmMgdXBkYXRlQXBwcm92ZXIoYXBwcm92ZXI6IFVwZGF0ZVNjZW5hcmlvQXBwcm92ZXIpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBjb25zdCBzaGFyZWRDaXBoZXJEYXRhID0gYXdhaXQgdGhpcy5rZXlHcmFwaC5lbmNyeXB0VG9TdHJpbmcoXG4gICAgICBhcHByb3Zlci5rZXlJZCxcbiAgICAgIGFwcHJvdmVyLnBsYWluU2hhcmVkQ2lwaGVyRGF0YVxuICAgICk7XG5cbiAgICBhd2FpdCB0aGlzLmxyQXBvbGxvLm11dGF0ZTxhbnk+KHtcbiAgICAgIG11dGF0aW9uOiBVcGRhdGVTY2VuYXJpb0FwcHJvdmVyTXV0YXRpb24sXG4gICAgICB2YXJpYWJsZXM6IHtcbiAgICAgICAgaW5wdXQ6IHtcbiAgICAgICAgICBhcHByb3ZlcklkOiBhcHByb3Zlci5hcHByb3ZlcklkLFxuICAgICAgICAgIHNoYXJlZEtleUlkOiBhcHByb3Zlci5rZXlJZCxcbiAgICAgICAgICBzaGFyZWRDaXBoZXJEYXRhLFxuICAgICAgICAgIHNoYXJlZENpcGhlckFwcHJvdmFsRGF0YTogJycsXG4gICAgICAgIH0sXG4gICAgICB9LFxuICAgIH0pO1xuICB9XG5cbiAgcHVibGljIGFzeW5jIGNyZWF0ZVNjZW5hcmlvQXBwcm92ZXJBc3NlbWJseShcbiAgICBpbnB1dDogQ3JlYXRlU2NlbmFyaW9BcHByb3ZhbEdyb3Vwc1xuICApOiBQcm9taXNlPHN0cmluZz4ge1xuICAgIGNvbnN0IGFzc2VtYmx5S2V5ID0gYXdhaXQgdGhpcy5rZXlGYWN0b3J5LmNyZWF0ZUtleSgpO1xuXG4gICAgY29uc3Qgc3ViamVjdEtleVdyYXBwZWRBc3NlbWJseUtleSA9IGF3YWl0IHRoaXMua2V5R3JhcGguZW5jcnlwdFRvU3RyaW5nKFxuICAgICAgaW5wdXQua2V5SWQsXG4gICAgICBhc3NlbWJseUtleS50b0pTT04odHJ1ZSlcbiAgICApO1xuXG4gICAgY29uc3QgYXNzZW1ibHlDaXBoZXJEYXRhID0gaW5wdXQucGxhaW5Bc3NlbWJseUNpcGhlckRhdGFcbiAgICAgID8gYXdhaXQgdGhpcy5rZXlHcmFwaC5lbmNyeXB0VG9TdHJpbmcoXG4gICAgICAgICAgYXNzZW1ibHlLZXksXG4gICAgICAgICAgaW5wdXQucGxhaW5Bc3NlbWJseUNpcGhlckRhdGFcbiAgICAgICAgKVxuICAgICAgOiAnJztcblxuICAgIGNvbnN0IHsgY3JlYXRlU2NlbmFyaW9BcHByb3ZlckFzc2VtYmx5IH0gPSBhd2FpdCB0aGlzLmxyQXBvbGxvLm11dGF0ZTxhbnk+KHtcbiAgICAgIG11dGF0aW9uOiBDcmVhdGVTY2VuYXJpb0FwcHJvdmVyQXNzZW1ibHlNdXRhdGlvbixcbiAgICAgIHZhcmlhYmxlczoge1xuICAgICAgICBpbnB1dDoge1xuICAgICAgICAgIHNjZW5hcmlvSWQ6IGlucHV0LnNjZW5hcmlvSWQsXG4gICAgICAgICAgc2luZ2xlUmVqZWN0OiBpbnB1dC5zaW5nbGVSZWplY3QsXG4gICAgICAgICAgcXVvcnVtOiBpbnB1dC5xdW9ydW0sXG4gICAgICAgICAgc3ViamVjdEtleUlkOiBpbnB1dC5rZXlJZCxcbiAgICAgICAgICBzdWJqZWN0S2V5V3JhcHBlZEFzc2VtYmx5S2V5LFxuICAgICAgICAgIGFzc2VtYmx5Q2lwaGVyRGF0YSxcbiAgICAgICAgICBjcmVhdGVTdWJBc3NlbWJsaWVzOiAoXG4gICAgICAgICAgICBhd2FpdCB0aGlzLm1hcEFwcHJvdmFsR3JvdXBzKFxuICAgICAgICAgICAgICBpbnB1dC5hcHByb3ZhbEdyb3VwcyxcbiAgICAgICAgICAgICAgaW5wdXQucXVvcnVtLFxuICAgICAgICAgICAgICBhc3NlbWJseUtleVxuICAgICAgICAgICAgKVxuICAgICAgICAgICkubWFwKCh4KSA9PiB7XG4gICAgICAgICAgICBjb25zdCB7IHVwZGF0ZUFwcHJvdmVycywgZGVsZXRlQXBwcm92ZXJzLCAuLi5zdWJBc3NlbWJseSB9ID0geDtcbiAgICAgICAgICAgIHJldHVybiBzdWJBc3NlbWJseTtcbiAgICAgICAgICB9KSxcbiAgICAgICAgICB1cGRhdGVSZWNlaXZlcnM6IGF3YWl0IHRoaXMucmV3cmFwUmVjZWl2ZXJzKFxuICAgICAgICAgICAgYXNzZW1ibHlLZXksXG4gICAgICAgICAgICBpbnB1dC5ldmVudCxcbiAgICAgICAgICAgIGlucHV0LnJlY2VpdmVyc1xuICAgICAgICAgICksXG4gICAgICAgIH0sXG4gICAgICB9LFxuICAgIH0pO1xuICAgIHJldHVybiBjcmVhdGVTY2VuYXJpb0FwcHJvdmVyQXNzZW1ibHkuc2NlbmFyaW8uYXBwcm92ZXJBc3NlbWJseS5hc3NlbWJseUtleVxuICAgICAgLmlkO1xuICB9XG5cbiAgcHVibGljIGFzeW5jIHVwZGF0ZVNjZW5hcmlvQXBwcm92ZXJBc3NlbWJseShcbiAgICBpbnB1dDogVXBkYXRlU2NlbmFyaW9BcHByb3ZhbEdyb3Vwc1xuICApOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBjb25zdCBhc3NlbWJseUtleSA9IGF3YWl0IHRoaXMua2V5R3JhcGguZ2V0S2V5KGlucHV0LmFzc2VtYmx5S2V5SWQpO1xuICAgIGNvbnN0IGFzc2VtYmx5Q2lwaGVyRGF0YSA9IGlucHV0LnBsYWluQXNzZW1ibHlDaXBoZXJEYXRhXG4gICAgICA/IGF3YWl0IHRoaXMua2V5R3JhcGguZW5jcnlwdFRvU3RyaW5nKFxuICAgICAgICAgIGFzc2VtYmx5S2V5Lmp3ayxcbiAgICAgICAgICBpbnB1dC5wbGFpbkFzc2VtYmx5Q2lwaGVyRGF0YVxuICAgICAgICApXG4gICAgICA6ICcnO1xuXG4gICAgY29uc3QgYXBwcm92YWxHcm91cHMgPSBhd2FpdCB0aGlzLm1hcEFwcHJvdmFsR3JvdXBzKFxuICAgICAgaW5wdXQuYXBwcm92YWxHcm91cHMsXG4gICAgICBpbnB1dC5xdW9ydW0sXG4gICAgICBhc3NlbWJseUtleS5qd2tcbiAgICApO1xuXG4gICAgYXdhaXQgdGhpcy5sckFwb2xsby5tdXRhdGU8YW55Pih7XG4gICAgICBtdXRhdGlvbjogVXBkYXRlU2NlbmFyaW9BcHByb3ZlckFzc2VtYmx5TXV0YXRpb24sXG4gICAgICB2YXJpYWJsZXM6IHtcbiAgICAgICAgaW5wdXQ6IHtcbiAgICAgICAgICBzY2VuYXJpb0lkOiBpbnB1dC5zY2VuYXJpb0lkLFxuICAgICAgICAgIHNpbmdsZVJlamVjdDogaW5wdXQuc2luZ2xlUmVqZWN0LFxuICAgICAgICAgIHF1b3J1bTogaW5wdXQucXVvcnVtLFxuICAgICAgICAgIGFzc2VtYmx5S2V5SWQ6IGFzc2VtYmx5S2V5LmlkLFxuICAgICAgICAgIGFzc2VtYmx5Q2lwaGVyRGF0YSxcbiAgICAgICAgICBjcmVhdGVTdWJBc3NlbWJsaWVzOiBhcHByb3ZhbEdyb3Vwc1xuICAgICAgICAgICAgLmZpbHRlcigoeCkgPT4gIXguc3ViQXNzZW1ibHlJZClcbiAgICAgICAgICAgIC5tYXAoKHgpID0+IHtcbiAgICAgICAgICAgICAgY29uc3QgeyB1cGRhdGVBcHByb3ZlcnMsIGRlbGV0ZUFwcHJvdmVycywgLi4uc3ViQXNzZW1ibHkgfSA9IHg7XG4gICAgICAgICAgICAgIHJldHVybiBzdWJBc3NlbWJseTtcbiAgICAgICAgICAgIH0pLFxuICAgICAgICAgIHVwZGF0ZVN1YkFzc2VtYmxpZXM6IGFwcHJvdmFsR3JvdXBzLmZpbHRlcigoeCkgPT4geC5zdWJBc3NlbWJseUlkKSxcbiAgICAgICAgICBkZWxldGVTdWJBc3NlbWJsaWVzOiBpbnB1dC5kZWxldGVkR3JvdXBJZHMsXG4gICAgICAgIH0sXG4gICAgICB9LFxuICAgIH0pO1xuICB9XG5cbiAgcHVibGljIGFzeW5jIGRlbGV0ZVNjZW5hcmlvQXBwcm92ZXJBc3NlbWJseShcbiAgICBzY2VuYXJpb0lkOiBzdHJpbmcsXG4gICAgZXZlbnQ6IHN0cmluZyxcbiAgICByZWNlaXZlcnM6IFJlY2VpdmVyW11cbiAgKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgYXdhaXQgdGhpcy5sckFwb2xsby5tdXRhdGU8YW55Pih7XG4gICAgICBtdXRhdGlvbjogRGVsZXRlU2NlbmFyaW9BcHByb3ZlckFzc2VtYmx5TXV0YXRpb24sXG4gICAgICB2YXJpYWJsZXM6IHtcbiAgICAgICAgaW5wdXQ6IHtcbiAgICAgICAgICBzY2VuYXJpb0lkLFxuICAgICAgICAgIHVwZGF0ZVJlY2VpdmVyczogYXdhaXQgdGhpcy5yZXdyYXBSZWNlaXZlcnMobnVsbCwgZXZlbnQsIHJlY2VpdmVycyksXG4gICAgICAgIH0sXG4gICAgICB9LFxuICAgIH0pO1xuICB9XG5cbiAgcHJpdmF0ZSBhc3luYyByZXdyYXBSZWNlaXZlcnMoXG4gICAgYXNzZW1ibHlLZXk6IEpXSy5LZXksXG4gICAgZXZlbnQ6IHN0cmluZyxcbiAgICByZWNlaXZlcnM6IFJlY2VpdmVyW11cbiAgKSB7XG4gICAgaWYgKCFyZWNlaXZlcnMgfHwgIXJlY2VpdmVycy5sZW5ndGgpIHtcbiAgICAgIHJldHVybiBbXTtcbiAgICB9XG5cbiAgICByZXR1cm4gYXdhaXQgUHJvbWlzZS5hbGwoXG4gICAgICByZWNlaXZlcnMubWFwKGFzeW5jIChyZWNlaXZlcikgPT4ge1xuICAgICAgICBjb25zdCBzaGFyZWRLZXkgPSBhd2FpdCB0aGlzLmtleUdyYXBoLmdldEtleShyZWNlaXZlci5rZXlJZCk7XG5cbiAgICAgICAgY29uc3QgcHJlcGFyZVJlY2VpdmVySXRlbSA9IGFzeW5jIChcbiAgICAgICAgICBpdGVtOiBSZWNlaXZlckNhdGVnb3J5IHwgUmVjZWl2ZXJSZWNvcmQsXG4gICAgICAgICAgaXRlbUtleUlkOiBzdHJpbmdcbiAgICAgICAgKSA9PiB7XG4gICAgICAgICAgY29uc3QgaXRlbUtleSA9IGF3YWl0IHRoaXMua2V5R3JhcGguZ2V0S2V5KGl0ZW1LZXlJZCk7XG4gICAgICAgICAgbGV0IHdyYXBwZWRJdGVtS2V5ID0gYXdhaXQgdGhpcy5rZXlHcmFwaC5lbmNyeXB0VG9TdHJpbmcoXG4gICAgICAgICAgICBzaGFyZWRLZXkuandrLFxuICAgICAgICAgICAgaXRlbUtleS5qd2sudG9KU09OKHRydWUpXG4gICAgICAgICAgKTtcblxuICAgICAgICAgIGlmIChhc3NlbWJseUtleSkge1xuICAgICAgICAgICAgd3JhcHBlZEl0ZW1LZXkgPSBhd2FpdCB0aGlzLmtleUdyYXBoLmVuY3J5cHRUb1N0cmluZyhcbiAgICAgICAgICAgICAgYXNzZW1ibHlLZXksXG4gICAgICAgICAgICAgIHdyYXBwZWRJdGVtS2V5XG4gICAgICAgICAgICApO1xuICAgICAgICAgIH1cblxuICAgICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICBhY2Nlc3NSb2xlOiBpdGVtLmFjY2Vzc0xldmVsLFxuICAgICAgICAgICAgc2hhcmVkS2V5SWQ6IHNoYXJlZEtleS5pZCxcbiAgICAgICAgICAgIHNoYXJlZENpcGhlckRhdGE6ICcnLFxuICAgICAgICAgICAgd3JhcHBlZEl0ZW1LZXksXG4gICAgICAgICAgfTtcbiAgICAgICAgfTtcblxuICAgICAgICAvLyBGb3IgZWFjaCByZWNlaXZlci1kaXJlY3RvcnlcbiAgICAgICAgY29uc3QgcmVjZWl2ZXJEaXJlY3RvcmllcyA9IGF3YWl0IFByb21pc2UuYWxsKFtcbiAgICAgICAgICAuLi5yZWNlaXZlci5jYXRlZ29yaWVzLm1hcChhc3luYyAoeCkgPT4gKHtcbiAgICAgICAgICAgIC4uLihhd2FpdCBwcmVwYXJlUmVjZWl2ZXJJdGVtKHgsIHguY2F0ZWdvcnkua2V5SWQpKSxcbiAgICAgICAgICAgIHJlY2VpdmVyRGlyZWN0b3J5SWQ6IHguaWQsXG4gICAgICAgICAgfSkpLFxuICAgICAgICAgIC4uLnJlY2VpdmVyLnJlY29yZHMubWFwKGFzeW5jICh4KSA9PiAoe1xuICAgICAgICAgICAgLi4uKGF3YWl0IHByZXBhcmVSZWNlaXZlckl0ZW0oeCwgeC5yZWNvcmQua2V5SWQpKSxcbiAgICAgICAgICAgIHJlY2VpdmVyRGlyZWN0b3J5SWQ6IHguaWQsXG4gICAgICAgICAgfSkpLFxuICAgICAgICBdKTtcblxuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgIHJlY2VpdmVySWQ6IHJlY2VpdmVyLmlkLFxuICAgICAgICAgIHNoYXJlZEtleUlkOiByZWNlaXZlci5rZXlJZCxcbiAgICAgICAgICByZWNlaXZlckRpcmVjdG9yaWVzLFxuICAgICAgICAgIHJlY2VpdmVyRmlsZXM6IFtdLFxuICAgICAgICAgIHNoYXJlZENpcGhlckRhdGE6IGF3YWl0IHRoaXMua2V5R3JhcGguZW5jcnlwdFRvU3RyaW5nKHNoYXJlZEtleS5qd2ssIHtcbiAgICAgICAgICAgIGV2ZW50LFxuICAgICAgICAgICAgbWVzc2FnZTogcmVjZWl2ZXIubWVzc2FnZSxcbiAgICAgICAgICB9KSxcbiAgICAgICAgfTtcbiAgICAgIH0pXG4gICAgKTtcbiAgfVxuXG4gIHByaXZhdGUgYXN5bmMgbWFwQXBwcm92YWxHcm91cHMoXG4gICAgYXBwcm92YWxHcm91cHM6IFVwZGF0ZVNjZW5hcmlvQXBwcm92YWxHcm91cFtdLFxuICAgIHF1b3J1bTogbnVtYmVyLFxuICAgIGFzc2VtYmx5S2V5OiBKV0suS2V5XG4gICkge1xuICAgIGNvbnN0IHNsaXBBc3NlbWJseSA9IGF3YWl0IHRoaXMuY3JlYXRlU2xpcEFzc2VtYmx5KFxuICAgICAgcXVvcnVtLFxuICAgICAgYXBwcm92YWxHcm91cHMsXG4gICAgICAoYXNzZW1ibHlLZXkudG9KU09OKHRydWUpIGFzIGFueSkua1xuICAgICk7XG4gICAgcmV0dXJuIGF3YWl0IFByb21pc2UuYWxsKFxuICAgICAgYXBwcm92YWxHcm91cHMubWFwKCh4LCBpbmRleCkgPT5cbiAgICAgICAgdGhpcy5tYXBBcHByb3ZhbEdyb3VwKHgsIHNsaXBBc3NlbWJseS5zdWJBc3NlbWJsaWVzW2luZGV4XSwgYXNzZW1ibHlLZXkpXG4gICAgICApXG4gICAgKTtcbiAgfVxuXG4gIHByaXZhdGUgYXN5bmMgbWFwQXBwcm92YWxHcm91cChcbiAgICBhcHByb3ZhbEdyb3VwOiBVcGRhdGVTY2VuYXJpb0FwcHJvdmFsR3JvdXAsXG4gICAgc3ViQXNzZW1ibHk6IHNsaXAuU3ViQXNzZW1ibHksXG4gICAgYXNzZW1ibHlLZXk6IEpXSy5LZXlcbiAgKSB7XG4gICAgY29uc3QgYXBwcm92ZXJzID0gYXdhaXQgdGhpcy5tYXBBcHByb3ZlcnMoXG4gICAgICBhcHByb3ZhbEdyb3VwLmFwcHJvdmVycyxcbiAgICAgIGFwcHJvdmFsR3JvdXAucXVvcnVtLFxuICAgICAgc3ViQXNzZW1ibHksXG4gICAgICBhc3NlbWJseUtleVxuICAgICk7XG5cbiAgICByZXR1cm4ge1xuICAgICAgc3ViQXNzZW1ibHlJZDogYXBwcm92YWxHcm91cC5zdWJBc3NlbWJseUlkLFxuICAgICAgc2luZ2xlUmVqZWN0OiBhcHByb3ZhbEdyb3VwLnNpbmdsZVJlamVjdCxcbiAgICAgIHF1b3J1bTogYXBwcm92YWxHcm91cC5xdW9ydW0sXG4gICAgICBzdWJBc3NlbWJseUNpcGhlckRhdGE6IGF3YWl0IHRoaXMua2V5R3JhcGguZW5jcnlwdFRvU3RyaW5nKFxuICAgICAgICBhc3NlbWJseUtleSxcbiAgICAgICAgYXBwcm92YWxHcm91cC5wbGFpblN1YkFzc2VtYmx5Q2lwaGVyRGF0YVxuICAgICAgKSxcbiAgICAgIGNyZWF0ZUFwcHJvdmVyczogYXBwcm92ZXJzLmZpbHRlcigoeCkgPT4gIXguYXBwcm92ZXJJZCksXG4gICAgICB1cGRhdGVBcHByb3ZlcnM6IGFwcHJvdmVycy5maWx0ZXIoKHgpID0+IHguYXBwcm92ZXJJZCksXG4gICAgICBkZWxldGVBcHByb3ZlcnM6IGFwcHJvdmFsR3JvdXAuZGVsZXRlZEFwcHJvdmVySWRzIHx8IFtdLFxuICAgIH07XG4gIH1cblxuICBwcml2YXRlIGFzeW5jIG1hcEFwcHJvdmVycyhcbiAgICBhcHByb3ZlcnM6IFVwZGF0ZVNjZW5hcmlvQXBwcm92ZXJbXSxcbiAgICBxdW9ydW06IG51bWJlcixcbiAgICBzdWJBc3NlbWJseTogc2xpcC5TdWJBc3NlbWJseSxcbiAgICBhc3NlbWJseUtleTogSldLLktleVxuICApIHtcbiAgICBjb25zdCB7IGs6IHJhd0Fzc2VtYmx5S2V5LCAuLi5hc3NlbWJseUtleVBhcmFtcyB9ID0gYXNzZW1ibHlLZXkudG9KU09OKFxuICAgICAgdHJ1ZVxuICAgICkgYXMgYW55O1xuICAgIGxldCBzaGFyZUlkeCA9IDA7XG5cbiAgICBjb25zdCBuZXh0UGFydGlhbEFzc2VtYmx5S2V5ID0gYXN5bmMgKHNoYXJlZEtleUp3azogSldLLktleSkgPT4ge1xuICAgICAgY29uc3Qgc2hhcmUgPSBzdWJBc3NlbWJseS5zaGFyZXNbc2hhcmVJZHhdO1xuICAgICAgLy8gSWYgcXVvcnVtIGlzIDEsIHRoZW4gdXNpbmcgdGhlIHNhbWUgc2hhcmUgZm9yIGV2ZXJ5IG1lbWJlci5cbiAgICAgIGlmIChxdW9ydW0gIT09IDEpIHtcbiAgICAgICAgKytzaGFyZUlkeDtcbiAgICAgIH1cbiAgICAgIGNvbnN0IHBhcnRpYWxBc3NlbWJseUtleTogUGFydGlhbEFzc2VtYmx5S2V5ID0ge1xuICAgICAgICBzbGlwMzk6IHtcbiAgICAgICAgICBzaGFyZSxcbiAgICAgICAgICBzdWJBc3NlbWJseToge1xuICAgICAgICAgICAgcXVvcnVtLFxuICAgICAgICAgICAgc2l6ZTogYXBwcm92ZXJzLmxlbmd0aCxcbiAgICAgICAgICB9LFxuICAgICAgICB9LFxuICAgICAgICBhc3NlbWJseUtleVBhcmFtcyxcbiAgICAgIH07XG4gICAgICByZXR1cm4gdGhpcy5rZXlHcmFwaC5lbmNyeXB0VG9TdHJpbmcoc2hhcmVkS2V5SndrLCBwYXJ0aWFsQXNzZW1ibHlLZXkpO1xuICAgIH07XG5cbiAgICByZXR1cm4gYXdhaXQgUHJvbWlzZS5hbGwoXG4gICAgICBhcHByb3ZlcnMubWFwKGFzeW5jICh4KSA9PiB7XG4gICAgICAgIGlmICh4LmFwcHJvdmVySWQpIHtcbiAgICAgICAgICBjb25zdCBzaGFyZWRLZXkgPSBhd2FpdCB0aGlzLmtleUdyYXBoLmdldEtleSh4LmtleUlkKTtcbiAgICAgICAgICBjb25zdCBzaGFyZWRDaXBoZXJEYXRhID0gYXdhaXQgdGhpcy5rZXlHcmFwaC5lbmNyeXB0VG9TdHJpbmcoXG4gICAgICAgICAgICB4LmtleUlkLFxuICAgICAgICAgICAgeC5wbGFpblNoYXJlZENpcGhlckRhdGFcbiAgICAgICAgICApO1xuICAgICAgICAgIGNvbnN0IHNoYXJlZENpcGhlckFwcHJvdmFsRGF0YSA9IGF3YWl0IHRoaXMua2V5R3JhcGguZW5jcnlwdFRvU3RyaW5nKFxuICAgICAgICAgICAgeC5rZXlJZCxcbiAgICAgICAgICAgIHguYXBwcm92YWxEYXRhXG4gICAgICAgICAgKTtcblxuICAgICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICBhcHByb3ZlcklkOiB4LmFwcHJvdmVySWQsXG4gICAgICAgICAgICBzaGFyZWRLZXlJZDogeC5rZXlJZCxcbiAgICAgICAgICAgIHNoYXJlZENpcGhlckRhdGE6IHNoYXJlZENpcGhlckRhdGEgfHwgJycsXG4gICAgICAgICAgICBzaGFyZWRDaXBoZXJBcHByb3ZhbERhdGE6IHNoYXJlZENpcGhlckFwcHJvdmFsRGF0YSB8fCAnJyxcbiAgICAgICAgICAgIHNoYXJlZENpcGhlclBhcnRpYWxBc3NlbWJseUtleTogYXdhaXQgbmV4dFBhcnRpYWxBc3NlbWJseUtleShcbiAgICAgICAgICAgICAgc2hhcmVkS2V5Lmp3a1xuICAgICAgICAgICAgKSxcbiAgICAgICAgICB9O1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGNvbnN0IHdyYXBwZWRDb250ZW50ID0gYXdhaXQgdGhpcy5rZXlNZXRhU2VydmljZS53cmFwQ29udGVudFdpdGhLZXkoXG4gICAgICAgICAgICB4LnBsYWluU2hhcmVkQ2lwaGVyRGF0YSxcbiAgICAgICAgICAgIHgudHJ1c3RlZFBhcnR5U2hhcmVkS2V5SWRcbiAgICAgICAgICApO1xuXG4gICAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgIHRwSWQ6IHgudHJ1c3RlZFBhcnR5SWQsXG4gICAgICAgICAgICB0cFNoYXJlZEtleUlkOiB4LnRydXN0ZWRQYXJ0eVNoYXJlZEtleUlkLFxuICAgICAgICAgICAgdHBTaGFyZWRLZXlXcmFwcGVkU2hhcmVkS2V5OiB3cmFwcGVkQ29udGVudC5yb290S2V5LndyYXBwZWRLZXksXG4gICAgICAgICAgICBzaGFyZWRDaXBoZXJEYXRhOiB3cmFwcGVkQ29udGVudC5jaXBoZXJNZXRhLFxuICAgICAgICAgICAgc2hhcmVkQ2lwaGVyQXBwcm92YWxEYXRhOiAnJyxcbiAgICAgICAgICAgIHNoYXJlZENpcGhlclBhcnRpYWxBc3NlbWJseUtleTogYXdhaXQgbmV4dFBhcnRpYWxBc3NlbWJseUtleShcbiAgICAgICAgICAgICAgd3JhcHBlZENvbnRlbnQua2V5XG4gICAgICAgICAgICApLFxuICAgICAgICAgIH07XG4gICAgICAgIH1cbiAgICAgIH0pXG4gICAgKTtcbiAgfVxuXG4gIC8vIFNwbGl0IGFzc2VtYmx5IGtleSBiZXR3ZWVuIGFsbCBleGlzdGluZyBhcHByb3ZlcnMuXG4gIHByaXZhdGUgYXN5bmMgY3JlYXRlU2xpcEFzc2VtYmx5KFxuICAgIHF1b3J1bTogbnVtYmVyLFxuICAgIGFwcHJvdmFsR3JvdXBzOiBVcGRhdGVTY2VuYXJpb0FwcHJvdmFsR3JvdXBbXSxcbiAgICByYXdBc3NlbWJseUtleTogc3RyaW5nXG4gICk6IFByb21pc2U8c2xpcC5Bc3NlbWJseT4ge1xuICAgIGNvbnN0IHNsaXBBc3NlbWJseSA9IG5ldyBzbGlwLkFzc2VtYmx5KHF1b3J1bSk7XG5cbiAgICBhcHByb3ZhbEdyb3Vwcy5mb3JFYWNoKCh4LCBpbmRleCkgPT4ge1xuICAgICAgbGV0IGFwcHJvdmVyQ291bnQgPSB4LmFwcHJvdmVycy5sZW5ndGg7XG5cbiAgICAgIC8vIHNsaXAzOSByZXN0cmljdHMgcXVvcnVtID09IDEgdG8gaGF2ZSBvbmx5IDEgbWVtYmVyLiBTbyB3ZSBqdXN0IHNoYXJlIHRoZSBzYW1lXG4gICAgICAvLyBwYXJ0aWFsIGtleSBmb3IgYWxsIHN1YiBhc3NlbWJseSBtZW1iZXJzLlxuICAgICAgaWYgKHgucXVvcnVtID09PSAxKSB7XG4gICAgICAgIGFwcHJvdmVyQ291bnQgPSAxO1xuICAgICAgfVxuICAgICAgc2xpcEFzc2VtYmx5LmFkZFN1YkFzc2VtYmx5KFxuICAgICAgICBuZXcgc2xpcC5TdWJBc3NlbWJseShpbmRleCwgeC5xdW9ydW0sIGFwcHJvdmVyQ291bnQpXG4gICAgICApO1xuICAgIH0pO1xuICAgIC8vIElzIHRoZXJlIGVub3VnaCBzdWIgYXNzZW1ibGllcyB0byBtZWV0IHF1b3J1bVxuICAgIGlmIChzbGlwQXNzZW1ibHkuc3ViQXNzZW1ibGllcy5sZW5ndGggPCBxdW9ydW0pIHtcbiAgICAgIHJldHVybiBudWxsO1xuICAgIH1cbiAgICBhd2FpdCB0aGlzLnNsaXAzOVNlcnZpY2UuZ2VuZXJhdGVTaGFyZXMoXG4gICAgICByYXdBc3NlbWJseUtleSxcbiAgICAgIFNjZW5hcmlvQXBwcm92ZXJTZXJ2aWNlLlNMSVAzOV9QQVNTUEhSQVNFLFxuICAgICAgc2xpcEFzc2VtYmx5XG4gICAgKTtcbiAgICByZXR1cm4gc2xpcEFzc2VtYmx5O1xuICB9XG59XG4iXX0=
@@ -0,0 +1,52 @@
1
+ import gql from 'graphql-tag';
2
+ import { KeyGraphField } from '../../_common/queries.gql';
3
+ import { TrustedPartyProperties } from '../../trusted-parties/trusted-party.gql';
4
+ export const ClaimantFields = `
5
+ id
6
+ tp {
7
+ ${TrustedPartyProperties}
8
+ }
9
+ sharedKey {
10
+ id
11
+ }
12
+ sharedCipherData
13
+ `;
14
+ export const GetScenarioClaimantQuery = gql `
15
+ query GetScenarioClaimantQuery(
16
+ $id: LrRelayIdInput!
17
+ ) {
18
+ scenarioClaimant(id: $id) {
19
+ ${ClaimantFields}
20
+ }
21
+ ${KeyGraphField}
22
+ }`;
23
+ export const AddScenarioClaimantMutation = gql `
24
+ mutation AddScenarioClaimantMutation($input: AddScenarioClaimantInput!) {
25
+ addScenarioClaimant(input: $input) {
26
+ claimant {
27
+ id
28
+ }
29
+ }
30
+ }
31
+ `;
32
+ export const UpdateScenarioClaimantMutation = gql `
33
+ mutation UpdateScenarioClaimantMutation(
34
+ $input: UpdateScenarioClaimantInput!
35
+ ) {
36
+ updateScenarioClaimant(input: $input) {
37
+ claimant {
38
+ id
39
+ }
40
+ }
41
+ }
42
+ `;
43
+ export const DeleteScenarioClaimantMutation = gql `
44
+ mutation DeleteScenarioClaimantMutation(
45
+ $input: DeleteScenarioClaimantInput!
46
+ ) {
47
+ deleteScenarioClaimant(input: $input) {
48
+ id
49
+ }
50
+ }
51
+ `;
52
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NlbmFyaW8tY2xhaW1hbnQuZ3FsLmpzIiwic291cmNlUm9vdCI6Ii9vcHQvYXRsYXNzaWFuL3BpcGVsaW5lcy9hZ2VudC9idWlsZC9wcm9qZWN0cy9jb3JlL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9zY2VuYXJpby9jbGFpbWFudHMvc2NlbmFyaW8tY2xhaW1hbnQuZ3FsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sR0FBRyxNQUFNLGFBQWEsQ0FBQztBQUM5QixPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDMUQsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFFakYsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUFHOzs7SUFHMUIsc0JBQXNCOzs7Ozs7Q0FNekIsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLHdCQUF3QixHQUFHLEdBQUcsQ0FBQTs7Ozs7TUFLckMsY0FBYzs7SUFFaEIsYUFBYTtFQUNmLENBQUM7QUFFSCxNQUFNLENBQUMsTUFBTSwyQkFBMkIsR0FBRyxHQUFHLENBQUE7Ozs7Ozs7O0NBUTdDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSw4QkFBOEIsR0FBRyxHQUFHLENBQUE7Ozs7Ozs7Ozs7Q0FVaEQsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLDhCQUE4QixHQUFHLEdBQUcsQ0FBQTs7Ozs7Ozs7Q0FRaEQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBncWwgZnJvbSAnZ3JhcGhxbC10YWcnO1xuaW1wb3J0IHsgS2V5R3JhcGhGaWVsZCB9IGZyb20gJy4uLy4uL19jb21tb24vcXVlcmllcy5ncWwnO1xuaW1wb3J0IHsgVHJ1c3RlZFBhcnR5UHJvcGVydGllcyB9IGZyb20gJy4uLy4uL3RydXN0ZWQtcGFydGllcy90cnVzdGVkLXBhcnR5LmdxbCc7XG5cbmV4cG9ydCBjb25zdCBDbGFpbWFudEZpZWxkcyA9IGBcbmlkXG50cCB7XG4gICR7VHJ1c3RlZFBhcnR5UHJvcGVydGllc31cbn1cbnNoYXJlZEtleSB7XG4gIGlkXG59XG5zaGFyZWRDaXBoZXJEYXRhXG5gO1xuXG5leHBvcnQgY29uc3QgR2V0U2NlbmFyaW9DbGFpbWFudFF1ZXJ5ID0gZ3FsYFxucXVlcnkgR2V0U2NlbmFyaW9DbGFpbWFudFF1ZXJ5KFxuICAkaWQ6IExyUmVsYXlJZElucHV0IVxuKSB7XG4gIHNjZW5hcmlvQ2xhaW1hbnQoaWQ6ICRpZCkge1xuICAgICR7Q2xhaW1hbnRGaWVsZHN9XG4gIH1cbiAgJHtLZXlHcmFwaEZpZWxkfVxufWA7XG5cbmV4cG9ydCBjb25zdCBBZGRTY2VuYXJpb0NsYWltYW50TXV0YXRpb24gPSBncWxgXG4gIG11dGF0aW9uIEFkZFNjZW5hcmlvQ2xhaW1hbnRNdXRhdGlvbigkaW5wdXQ6IEFkZFNjZW5hcmlvQ2xhaW1hbnRJbnB1dCEpIHtcbiAgICBhZGRTY2VuYXJpb0NsYWltYW50KGlucHV0OiAkaW5wdXQpIHtcbiAgICAgIGNsYWltYW50IHtcbiAgICAgICAgaWRcbiAgICAgIH1cbiAgICB9XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBVcGRhdGVTY2VuYXJpb0NsYWltYW50TXV0YXRpb24gPSBncWxgXG4gIG11dGF0aW9uIFVwZGF0ZVNjZW5hcmlvQ2xhaW1hbnRNdXRhdGlvbihcbiAgICAkaW5wdXQ6IFVwZGF0ZVNjZW5hcmlvQ2xhaW1hbnRJbnB1dCFcbiAgKSB7XG4gICAgdXBkYXRlU2NlbmFyaW9DbGFpbWFudChpbnB1dDogJGlucHV0KSB7XG4gICAgICBjbGFpbWFudCB7XG4gICAgICAgIGlkXG4gICAgICB9XG4gICAgfVxuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgRGVsZXRlU2NlbmFyaW9DbGFpbWFudE11dGF0aW9uID0gZ3FsYFxuICBtdXRhdGlvbiBEZWxldGVTY2VuYXJpb0NsYWltYW50TXV0YXRpb24oXG4gICAgJGlucHV0OiBEZWxldGVTY2VuYXJpb0NsYWltYW50SW5wdXQhXG4gICkge1xuICAgIGRlbGV0ZVNjZW5hcmlvQ2xhaW1hbnQoaW5wdXQ6ICRpbnB1dCkge1xuICAgICAgaWRcbiAgICB9XG4gIH1cbmA7XG4iXX0=
@@ -0,0 +1,97 @@
1
+ import { __awaiter } from "tslib";
2
+ import { Injectable } from '@angular/core';
3
+ import { LrApolloService } from '../../api/lr-apollo.service';
4
+ import { KeyGraphService } from '../../cryptography/key-graph.service';
5
+ import { KeyMetaService } from '../../cryptography/key-meta.service';
6
+ import { TrustedPartyService } from '../../trusted-parties/trusted-party.service';
7
+ import { DeleteScenarioClaimantMutation, UpdateScenarioClaimantMutation, GetScenarioClaimantQuery, AddScenarioClaimantMutation, } from './scenario-claimant.gql';
8
+ import * as i0 from "@angular/core";
9
+ import * as i1 from "../../api/lr-apollo.service";
10
+ import * as i2 from "../../cryptography/key-meta.service";
11
+ import * as i3 from "../../cryptography/key-graph.service";
12
+ import * as i4 from "../../trusted-parties/trusted-party.service";
13
+ export class ScenarioClaimantService {
14
+ constructor(lrApollo, keyMetaService, keyGraph, tpService) {
15
+ this.lrApollo = lrApollo;
16
+ this.keyMetaService = keyMetaService;
17
+ this.keyGraph = keyGraph;
18
+ this.tpService = tpService;
19
+ }
20
+ getClaimant(claimantId) {
21
+ return __awaiter(this, void 0, void 0, function* () {
22
+ const { scenarioClaimant } = yield this.lrApollo.query({
23
+ query: GetScenarioClaimantQuery,
24
+ variables: {
25
+ id: claimantId,
26
+ },
27
+ });
28
+ return this.mapClaimant(scenarioClaimant);
29
+ });
30
+ }
31
+ mapClaimant(claimant) {
32
+ return __awaiter(this, void 0, void 0, function* () {
33
+ const { message } = yield this.keyGraph.decryptFromString(claimant.sharedKey.id, claimant.sharedCipherData);
34
+ return {
35
+ id: claimant.id,
36
+ keyId: claimant.sharedKey.id,
37
+ trustedParty: yield this.tpService.mapTrustedParty(claimant.tp),
38
+ message,
39
+ };
40
+ });
41
+ }
42
+ addClaimant(claimant) {
43
+ return __awaiter(this, void 0, void 0, function* () {
44
+ const wrappedContent = yield this.keyMetaService.wrapContentWithKey(claimant.plainSharedCipherData, claimant.trustedPartySharedKeyId);
45
+ const { addScenarioClaimant } = yield this.lrApollo.mutate({
46
+ mutation: AddScenarioClaimantMutation,
47
+ variables: {
48
+ input: {
49
+ scenarioId: claimant.scenarioId,
50
+ tpId: claimant.trustedPartyId,
51
+ tpSharedKeyId: claimant.trustedPartySharedKeyId,
52
+ tpSharedKeyWrappedSharedKey: wrappedContent.rootKey.wrappedKey,
53
+ sharedCipherData: wrappedContent.cipherMeta,
54
+ },
55
+ },
56
+ });
57
+ return addScenarioClaimant.claimant.id;
58
+ });
59
+ }
60
+ updateClaimant(claimant) {
61
+ return __awaiter(this, void 0, void 0, function* () {
62
+ const sharedCipherData = yield this.keyGraph.encryptToString(claimant.keyId, claimant.plainSharedCipherData);
63
+ const res = yield this.lrApollo.mutate({
64
+ mutation: UpdateScenarioClaimantMutation,
65
+ variables: {
66
+ input: {
67
+ claimantId: claimant.id,
68
+ sharedKeyId: claimant.keyId,
69
+ sharedCipherData,
70
+ },
71
+ },
72
+ });
73
+ return res.updateScenarioClaimant.claimant.id;
74
+ });
75
+ }
76
+ deleteClaimant(claimantId) {
77
+ return __awaiter(this, void 0, void 0, function* () {
78
+ yield this.lrApollo.mutate({
79
+ mutation: DeleteScenarioClaimantMutation,
80
+ variables: { input: { claimantId } },
81
+ });
82
+ });
83
+ }
84
+ }
85
+ ScenarioClaimantService.ɵprov = i0.ɵɵdefineInjectable({ factory: function ScenarioClaimantService_Factory() { return new ScenarioClaimantService(i0.ɵɵinject(i1.LrApolloService), i0.ɵɵinject(i2.KeyMetaService), i0.ɵɵinject(i3.KeyGraphService), i0.ɵɵinject(i4.TrustedPartyService)); }, token: ScenarioClaimantService, providedIn: "root" });
86
+ ScenarioClaimantService.decorators = [
87
+ { type: Injectable, args: [{
88
+ providedIn: 'root',
89
+ },] }
90
+ ];
91
+ ScenarioClaimantService.ctorParameters = () => [
92
+ { type: LrApolloService },
93
+ { type: KeyMetaService },
94
+ { type: KeyGraphService },
95
+ { type: TrustedPartyService }
96
+ ];
97
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NlbmFyaW8tY2xhaW1hbnQuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIvb3B0L2F0bGFzc2lhbi9waXBlbGluZXMvYWdlbnQvYnVpbGQvcHJvamVjdHMvY29yZS9zcmMvIiwic291cmNlcyI6WyJsaWIvc2NlbmFyaW8vY2xhaW1hbnRzL3NjZW5hcmlvLWNsYWltYW50LnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQzlELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQztBQUN2RSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFDckUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sNkNBQTZDLENBQUM7QUFDbEYsT0FBTyxFQUNMLDhCQUE4QixFQUM5Qiw4QkFBOEIsRUFDOUIsd0JBQXdCLEVBQ3hCLDJCQUEyQixHQUM1QixNQUFNLHlCQUF5QixDQUFDOzs7Ozs7QUFVakMsTUFBTSxPQUFPLHVCQUF1QjtJQUNsQyxZQUNVLFFBQXlCLEVBQ3pCLGNBQThCLEVBQzlCLFFBQXlCLEVBQ3pCLFNBQThCO1FBSDlCLGFBQVEsR0FBUixRQUFRLENBQWlCO1FBQ3pCLG1CQUFjLEdBQWQsY0FBYyxDQUFnQjtRQUM5QixhQUFRLEdBQVIsUUFBUSxDQUFpQjtRQUN6QixjQUFTLEdBQVQsU0FBUyxDQUFxQjtJQUNyQyxDQUFDO0lBRVMsV0FBVyxDQUFDLFVBQWtCOztZQUN6QyxNQUFNLEVBQUUsZ0JBQWdCLEVBQUUsR0FBRyxNQUFNLElBQUksQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFNO2dCQUMxRCxLQUFLLEVBQUUsd0JBQXdCO2dCQUMvQixTQUFTLEVBQUU7b0JBQ1QsRUFBRSxFQUFFLFVBQVU7aUJBQ2Y7YUFDRixDQUFDLENBQUM7WUFDSCxPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztRQUM1QyxDQUFDO0tBQUE7SUFFWSxXQUFXLENBQUMsUUFBYTs7WUFDcEMsTUFBTSxFQUFFLE9BQU8sRUFBRSxHQUFHLE1BQU0sSUFBSSxDQUFDLFFBQVEsQ0FBQyxpQkFBaUIsQ0FFdEQsUUFBUSxDQUFDLFNBQVMsQ0FBQyxFQUFFLEVBQUUsUUFBUSxDQUFDLGdCQUFnQixDQUFDLENBQUM7WUFFckQsT0FBTztnQkFDTCxFQUFFLEVBQUUsUUFBUSxDQUFDLEVBQUU7Z0JBQ2YsS0FBSyxFQUFFLFFBQVEsQ0FBQyxTQUFTLENBQUMsRUFBRTtnQkFDNUIsWUFBWSxFQUFFLE1BQU0sSUFBSSxDQUFDLFNBQVMsQ0FBQyxlQUFlLENBQUMsUUFBUSxDQUFDLEVBQUUsQ0FBQztnQkFDL0QsT0FBTzthQUNSLENBQUM7UUFDSixDQUFDO0tBQUE7SUFFWSxXQUFXLENBQUMsUUFBNkI7O1lBQ3BELE1BQU0sY0FBYyxHQUFHLE1BQU0sSUFBSSxDQUFDLGNBQWMsQ0FBQyxrQkFBa0IsQ0FDakUsUUFBUSxDQUFDLHFCQUFxQixFQUM5QixRQUFRLENBQUMsdUJBQXVCLENBQ2pDLENBQUM7WUFFRixNQUFNLEVBQUUsbUJBQW1CLEVBQUUsR0FBRyxNQUFNLElBQUksQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFNO2dCQUM5RCxRQUFRLEVBQUUsMkJBQTJCO2dCQUNyQyxTQUFTLEVBQUU7b0JBQ1QsS0FBSyxFQUFFO3dCQUNMLFVBQVUsRUFBRSxRQUFRLENBQUMsVUFBVTt3QkFDL0IsSUFBSSxFQUFFLFFBQVEsQ0FBQyxjQUFjO3dCQUM3QixhQUFhLEVBQUUsUUFBUSxDQUFDLHVCQUF1Qjt3QkFDL0MsMkJBQTJCLEVBQUUsY0FBYyxDQUFDLE9BQU8sQ0FBQyxVQUFVO3dCQUM5RCxnQkFBZ0IsRUFBRSxjQUFjLENBQUMsVUFBVTtxQkFDNUM7aUJBQ0Y7YUFDRixDQUFDLENBQUM7WUFDSCxPQUFPLG1CQUFtQixDQUFDLFFBQVEsQ0FBQyxFQUFFLENBQUM7UUFDekMsQ0FBQztLQUFBO0lBRVksY0FBYyxDQUN6QixRQUFnQzs7WUFFaEMsTUFBTSxnQkFBZ0IsR0FBRyxNQUFNLElBQUksQ0FBQyxRQUFRLENBQUMsZUFBZSxDQUMxRCxRQUFRLENBQUMsS0FBSyxFQUNkLFFBQVEsQ0FBQyxxQkFBcUIsQ0FDL0IsQ0FBQztZQUVGLE1BQU0sR0FBRyxHQUFHLE1BQU0sSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQU07Z0JBQzFDLFFBQVEsRUFBRSw4QkFBOEI7Z0JBQ3hDLFNBQVMsRUFBRTtvQkFDVCxLQUFLLEVBQUU7d0JBQ0wsVUFBVSxFQUFFLFFBQVEsQ0FBQyxFQUFFO3dCQUN2QixXQUFXLEVBQUUsUUFBUSxDQUFDLEtBQUs7d0JBQzNCLGdCQUFnQjtxQkFDakI7aUJBQ0Y7YUFDRixDQUFDLENBQUM7WUFDSCxPQUFPLEdBQUcsQ0FBQyxzQkFBc0IsQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDO1FBQ2hELENBQUM7S0FBQTtJQUVZLGNBQWMsQ0FBQyxVQUFrQjs7WUFDNUMsTUFBTSxJQUFJLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBTTtnQkFDOUIsUUFBUSxFQUFFLDhCQUE4QjtnQkFDeEMsU0FBUyxFQUFFLEVBQUUsS0FBSyxFQUFFLEVBQUUsVUFBVSxFQUFFLEVBQUU7YUFDckMsQ0FBQyxDQUFDO1FBQ0wsQ0FBQztLQUFBOzs7O1lBakZGLFVBQVUsU0FBQztnQkFDVixVQUFVLEVBQUUsTUFBTTthQUNuQjs7O1lBbEJRLGVBQWU7WUFFZixjQUFjO1lBRGQsZUFBZTtZQUVmLG1CQUFtQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IExyQXBvbGxvU2VydmljZSB9IGZyb20gJy4uLy4uL2FwaS9sci1hcG9sbG8uc2VydmljZSc7XG5pbXBvcnQgeyBLZXlHcmFwaFNlcnZpY2UgfSBmcm9tICcuLi8uLi9jcnlwdG9ncmFwaHkva2V5LWdyYXBoLnNlcnZpY2UnO1xuaW1wb3J0IHsgS2V5TWV0YVNlcnZpY2UgfSBmcm9tICcuLi8uLi9jcnlwdG9ncmFwaHkva2V5LW1ldGEuc2VydmljZSc7XG5pbXBvcnQgeyBUcnVzdGVkUGFydHlTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vdHJ1c3RlZC1wYXJ0aWVzL3RydXN0ZWQtcGFydHkuc2VydmljZSc7XG5pbXBvcnQge1xuICBEZWxldGVTY2VuYXJpb0NsYWltYW50TXV0YXRpb24sXG4gIFVwZGF0ZVNjZW5hcmlvQ2xhaW1hbnRNdXRhdGlvbixcbiAgR2V0U2NlbmFyaW9DbGFpbWFudFF1ZXJ5LFxuICBBZGRTY2VuYXJpb0NsYWltYW50TXV0YXRpb24sXG59IGZyb20gJy4vc2NlbmFyaW8tY2xhaW1hbnQuZ3FsJztcbmltcG9ydCB7XG4gIENsYWltYW50LFxuICBBZGRTY2VuYXJpb0NsYWltYW50LFxuICBVcGRhdGVTY2VuYXJpb0NsYWltYW50LFxufSBmcm9tICcuL3NjZW5hcmlvLWNsYWltYW50LnR5cGVzJztcblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCcsXG59KVxuZXhwb3J0IGNsYXNzIFNjZW5hcmlvQ2xhaW1hbnRTZXJ2aWNlIHtcbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSBsckFwb2xsbzogTHJBcG9sbG9TZXJ2aWNlLFxuICAgIHByaXZhdGUga2V5TWV0YVNlcnZpY2U6IEtleU1ldGFTZXJ2aWNlLFxuICAgIHByaXZhdGUga2V5R3JhcGg6IEtleUdyYXBoU2VydmljZSxcbiAgICBwcml2YXRlIHRwU2VydmljZTogVHJ1c3RlZFBhcnR5U2VydmljZVxuICApIHt9XG5cbiAgcHVibGljIGFzeW5jIGdldENsYWltYW50KGNsYWltYW50SWQ6IHN0cmluZyk6IFByb21pc2U8Q2xhaW1hbnQ+IHtcbiAgICBjb25zdCB7IHNjZW5hcmlvQ2xhaW1hbnQgfSA9IGF3YWl0IHRoaXMubHJBcG9sbG8ucXVlcnk8YW55Pih7XG4gICAgICBxdWVyeTogR2V0U2NlbmFyaW9DbGFpbWFudFF1ZXJ5LFxuICAgICAgdmFyaWFibGVzOiB7XG4gICAgICAgIGlkOiBjbGFpbWFudElkLFxuICAgICAgfSxcbiAgICB9KTtcbiAgICByZXR1cm4gdGhpcy5tYXBDbGFpbWFudChzY2VuYXJpb0NsYWltYW50KTtcbiAgfVxuXG4gIHB1YmxpYyBhc3luYyBtYXBDbGFpbWFudChjbGFpbWFudDogYW55KTogUHJvbWlzZTxDbGFpbWFudD4ge1xuICAgIGNvbnN0IHsgbWVzc2FnZSB9ID0gYXdhaXQgdGhpcy5rZXlHcmFwaC5kZWNyeXB0RnJvbVN0cmluZzx7XG4gICAgICBtZXNzYWdlOiBzdHJpbmc7XG4gICAgfT4oY2xhaW1hbnQuc2hhcmVkS2V5LmlkLCBjbGFpbWFudC5zaGFyZWRDaXBoZXJEYXRhKTtcblxuICAgIHJldHVybiB7XG4gICAgICBpZDogY2xhaW1hbnQuaWQsXG4gICAgICBrZXlJZDogY2xhaW1hbnQuc2hhcmVkS2V5LmlkLFxuICAgICAgdHJ1c3RlZFBhcnR5OiBhd2FpdCB0aGlzLnRwU2VydmljZS5tYXBUcnVzdGVkUGFydHkoY2xhaW1hbnQudHApLFxuICAgICAgbWVzc2FnZSxcbiAgICB9O1xuICB9XG5cbiAgcHVibGljIGFzeW5jIGFkZENsYWltYW50KGNsYWltYW50OiBBZGRTY2VuYXJpb0NsYWltYW50KTogUHJvbWlzZTxzdHJpbmc+IHtcbiAgICBjb25zdCB3cmFwcGVkQ29udGVudCA9IGF3YWl0IHRoaXMua2V5TWV0YVNlcnZpY2Uud3JhcENvbnRlbnRXaXRoS2V5KFxuICAgICAgY2xhaW1hbnQucGxhaW5TaGFyZWRDaXBoZXJEYXRhLFxuICAgICAgY2xhaW1hbnQudHJ1c3RlZFBhcnR5U2hhcmVkS2V5SWRcbiAgICApO1xuXG4gICAgY29uc3QgeyBhZGRTY2VuYXJpb0NsYWltYW50IH0gPSBhd2FpdCB0aGlzLmxyQXBvbGxvLm11dGF0ZTxhbnk+KHtcbiAgICAgIG11dGF0aW9uOiBBZGRTY2VuYXJpb0NsYWltYW50TXV0YXRpb24sXG4gICAgICB2YXJpYWJsZXM6IHtcbiAgICAgICAgaW5wdXQ6IHtcbiAgICAgICAgICBzY2VuYXJpb0lkOiBjbGFpbWFudC5zY2VuYXJpb0lkLFxuICAgICAgICAgIHRwSWQ6IGNsYWltYW50LnRydXN0ZWRQYXJ0eUlkLFxuICAgICAgICAgIHRwU2hhcmVkS2V5SWQ6IGNsYWltYW50LnRydXN0ZWRQYXJ0eVNoYXJlZEtleUlkLFxuICAgICAgICAgIHRwU2hhcmVkS2V5V3JhcHBlZFNoYXJlZEtleTogd3JhcHBlZENvbnRlbnQucm9vdEtleS53cmFwcGVkS2V5LFxuICAgICAgICAgIHNoYXJlZENpcGhlckRhdGE6IHdyYXBwZWRDb250ZW50LmNpcGhlck1ldGEsXG4gICAgICAgIH0sXG4gICAgICB9LFxuICAgIH0pO1xuICAgIHJldHVybiBhZGRTY2VuYXJpb0NsYWltYW50LmNsYWltYW50LmlkO1xuICB9XG5cbiAgcHVibGljIGFzeW5jIHVwZGF0ZUNsYWltYW50KFxuICAgIGNsYWltYW50OiBVcGRhdGVTY2VuYXJpb0NsYWltYW50XG4gICk6IFByb21pc2U8c3RyaW5nPiB7XG4gICAgY29uc3Qgc2hhcmVkQ2lwaGVyRGF0YSA9IGF3YWl0IHRoaXMua2V5R3JhcGguZW5jcnlwdFRvU3RyaW5nKFxuICAgICAgY2xhaW1hbnQua2V5SWQsXG4gICAgICBjbGFpbWFudC5wbGFpblNoYXJlZENpcGhlckRhdGFcbiAgICApO1xuXG4gICAgY29uc3QgcmVzID0gYXdhaXQgdGhpcy5sckFwb2xsby5tdXRhdGU8YW55Pih7XG4gICAgICBtdXRhdGlvbjogVXBkYXRlU2NlbmFyaW9DbGFpbWFudE11dGF0aW9uLFxuICAgICAgdmFyaWFibGVzOiB7XG4gICAgICAgIGlucHV0OiB7XG4gICAgICAgICAgY2xhaW1hbnRJZDogY2xhaW1hbnQuaWQsXG4gICAgICAgICAgc2hhcmVkS2V5SWQ6IGNsYWltYW50LmtleUlkLFxuICAgICAgICAgIHNoYXJlZENpcGhlckRhdGEsXG4gICAgICAgIH0sXG4gICAgICB9LFxuICAgIH0pO1xuICAgIHJldHVybiByZXMudXBkYXRlU2NlbmFyaW9DbGFpbWFudC5jbGFpbWFudC5pZDtcbiAgfVxuXG4gIHB1YmxpYyBhc3luYyBkZWxldGVDbGFpbWFudChjbGFpbWFudElkOiBzdHJpbmcpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBhd2FpdCB0aGlzLmxyQXBvbGxvLm11dGF0ZTxhbnk+KHtcbiAgICAgIG11dGF0aW9uOiBEZWxldGVTY2VuYXJpb0NsYWltYW50TXV0YXRpb24sXG4gICAgICB2YXJpYWJsZXM6IHsgaW5wdXQ6IHsgY2xhaW1hbnRJZCB9IH0sXG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
@@ -0,0 +1 @@
1
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NlbmFyaW8tY2xhaW1hbnQudHlwZXMuanMiLCJzb3VyY2VSb290IjoiL29wdC9hdGxhc3NpYW4vcGlwZWxpbmVzL2FnZW50L2J1aWxkL3Byb2plY3RzL2NvcmUvc3JjLyIsInNvdXJjZXMiOlsibGliL3NjZW5hcmlvL2NsYWltYW50cy9zY2VuYXJpby1jbGFpbWFudC50eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVHJ1c3RlZFBhcnR5IH0gZnJvbSAnLi4vLi4vdHJ1c3RlZC1wYXJ0aWVzL3RydXN0ZWQtcGFydHkudHlwZXMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIENsYWltYW50IHtcbiAgaWQ6IHN0cmluZztcbiAga2V5SWQ6IHN0cmluZztcbiAgdHJ1c3RlZFBhcnR5OiBUcnVzdGVkUGFydHk7XG4gIG1lc3NhZ2U/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQWRkU2NlbmFyaW9DbGFpbWFudCB7XG4gIHNjZW5hcmlvSWQ6IHN0cmluZztcbiAgdHJ1c3RlZFBhcnR5SWQ6IHN0cmluZztcbiAgdHJ1c3RlZFBhcnR5U2hhcmVkS2V5SWQ6IHN0cmluZztcbiAgcGxhaW5TaGFyZWRDaXBoZXJEYXRhOiBvYmplY3Q7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVXBkYXRlU2NlbmFyaW9DbGFpbWFudCB7XG4gIGlkOiBzdHJpbmc7XG4gIGtleUlkOiBzdHJpbmc7XG4gIHBsYWluU2hhcmVkQ2lwaGVyRGF0YTogb2JqZWN0O1xufVxuIl19