@lifeready/core 1.0.21 → 1.0.23

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 (277) hide show
  1. package/bundles/lifeready-core.umd.js +10612 -10527
  2. package/bundles/lifeready-core.umd.js.map +1 -1
  3. package/bundles/lifeready-core.umd.min.js +1 -15
  4. package/bundles/lifeready-core.umd.min.js.map +1 -1
  5. package/esm2015/lib/_common/ast.js +2 -1
  6. package/esm2015/lib/_common/deferred-promise.js +1 -1
  7. package/esm2015/lib/_common/exceptions.js +1 -1
  8. package/esm2015/lib/_common/queries.gql.js +1 -1
  9. package/esm2015/lib/_common/run-outside-angular.js +3 -2
  10. package/esm2015/lib/_common/types.js +2 -1
  11. package/esm2015/lib/_common/utils.js +2 -1
  12. package/esm2015/lib/api/lr-apollo.service.js +4 -3
  13. package/esm2015/lib/api/lr-graphql/index.js +1 -1
  14. package/esm2015/lib/api/lr-graphql/lr-graphql.service.js +9 -8
  15. package/esm2015/lib/api/lr-graphql/lr-merged-mutation.js +5 -6
  16. package/esm2015/lib/api/lr-graphql/lr-mutation-base.js +1 -1
  17. package/esm2015/lib/api/lr-graphql/lr-mutation.js +3 -3
  18. package/esm2015/lib/api/lr-graphql/lr.service.js +1 -1
  19. package/esm2015/lib/api/query-processor/common-processors.service.js +4 -3
  20. package/esm2015/lib/api/query-processor/index.js +1 -1
  21. package/esm2015/lib/api/query-processor/query-processor.service.js +5 -4
  22. package/esm2015/lib/api/query-processor/tp-password-reset-processor.service.js +8 -7
  23. package/esm2015/lib/api/types/graphql.types.js +2 -1
  24. package/esm2015/lib/api/types/index.js +1 -1
  25. package/esm2015/lib/api/types/lr-graphql.types.js +1 -1
  26. package/esm2015/lib/auth/auth.config.js +1 -1
  27. package/esm2015/lib/auth/auth.gql.js +1 -28
  28. package/esm2015/lib/auth/auth.types.js +1 -1
  29. package/esm2015/lib/auth/life-ready-auth.service.js +36 -32
  30. package/esm2015/lib/category/category-meta.service.js +1 -1
  31. package/esm2015/lib/category/category.gql.js +3 -2
  32. package/esm2015/lib/category/category.service.js +9 -8
  33. package/esm2015/lib/category/category.types.js +1 -1
  34. package/esm2015/lib/contact-card/contact-card.gql.js +79 -0
  35. package/esm2015/lib/contact-card/contact-card.service.js +156 -0
  36. package/esm2015/lib/contact-card/contact-card2.gql.js +29 -0
  37. package/esm2015/lib/contact-card/contact-card2.service.js +103 -0
  38. package/esm2015/lib/encryption/encryption.service.js +190 -0
  39. package/esm2015/lib/file-upload/file-upload.service.js +74 -0
  40. package/esm2015/lib/file-upload/file-upload.types.js +2 -0
  41. package/esm2015/lib/idle/idle.service.js +168 -0
  42. package/esm2015/lib/idle/idle.types.js +7 -0
  43. package/esm2015/lib/item2/item2.gql.js +127 -0
  44. package/esm2015/lib/item2/item2.gql.private.js +23 -0
  45. package/esm2015/lib/item2/item2.service.js +519 -0
  46. package/esm2015/lib/item2/item2.types.js +2 -0
  47. package/esm2015/lib/key/key-factory.service.js +237 -0
  48. package/esm2015/lib/key/key-graph.service.js +300 -0
  49. package/esm2015/lib/key/key-meta.service.js +201 -0
  50. package/esm2015/lib/{cryptography → key}/key.service.js +4 -4
  51. package/esm2015/lib/key/key.types.js +11 -0
  52. package/esm2015/lib/key-exchange/key-exchange.gql.js +188 -0
  53. package/esm2015/lib/key-exchange/key-exchange.service.js +441 -0
  54. package/esm2015/lib/key-exchange/key-exchange.types.js +7 -0
  55. package/esm2015/lib/key-exchange/key-exchange2.gql.js +171 -0
  56. package/esm2015/lib/key-exchange/key-exchange2.service.js +500 -0
  57. package/esm2015/lib/lbop/lbop.service.js +357 -0
  58. package/esm2015/lib/life-ready.config.js +2 -1
  59. package/esm2015/lib/life-ready.module.js +2 -27
  60. package/esm2015/lib/lock/lock.gql.js +40 -0
  61. package/esm2015/lib/lock/lock.service.js +64 -0
  62. package/esm2015/lib/message/message.gql.js +32 -0
  63. package/esm2015/lib/message/message.service.js +118 -0
  64. package/esm2015/lib/message/message.types.js +2 -0
  65. package/esm2015/lib/notification/notification.gql.js +1 -1
  66. package/esm2015/lib/notification/notification.service.js +2 -2
  67. package/esm2015/lib/password/password.gql.js +28 -0
  68. package/esm2015/lib/password/password.service.js +316 -0
  69. package/esm2015/lib/persist/persist.service.js +181 -0
  70. package/esm2015/lib/plan/plan.gql.js +1 -1
  71. package/esm2015/lib/plan/plan.service.js +3 -2
  72. package/esm2015/lib/plan/plan.types.js +1 -1
  73. package/esm2015/lib/profile/profile-details.service.js +215 -0
  74. package/esm2015/lib/profile/profile.gql.js +98 -0
  75. package/esm2015/lib/profile/profile.service.js +170 -0
  76. package/esm2015/lib/profile/profile.types.js +34 -0
  77. package/esm2015/lib/record/record-attachment.service.js +16 -15
  78. package/esm2015/lib/record/record.gql.js +1 -1
  79. package/esm2015/lib/record/record.service.js +8 -8
  80. package/esm2015/lib/record/record.types.js +1 -1
  81. package/esm2015/lib/record-type/record-type.service.js +1 -1
  82. package/esm2015/lib/record-type/record-type.types.js +1 -1
  83. package/esm2015/lib/register/register.service.js +173 -0
  84. package/esm2015/lib/scenario/scenario.constants.js +1 -1
  85. package/esm2015/lib/scenario/scenario.controller.js +2 -2
  86. package/esm2015/lib/scenario/scenario.gql.js +1 -1
  87. package/esm2015/lib/scenario/scenario.private.gql.js +198 -0
  88. package/esm2015/lib/scenario/scenario.service.js +19 -17
  89. package/esm2015/lib/scenario/scenario.types.js +2 -1
  90. package/esm2015/lib/shared-contact-card/shared-contact-card.service.js +119 -0
  91. package/esm2015/lib/shared-contact-card/shared-contact-card2.gql.js +41 -0
  92. package/esm2015/lib/shared-contact-card/shared-contact-card2.service.js +117 -0
  93. package/esm2015/lib/slip39/slip39.service.js +167 -0
  94. package/esm2015/lib/time/time.service.js +146 -0
  95. package/esm2015/lib/tp-assembly/tp-assembly.js +365 -0
  96. package/esm2015/lib/tp-assembly/tp-assembly.private.gql.js +22 -0
  97. package/esm2015/lib/tp-assembly/tp-assembly.types.js +2 -0
  98. package/esm2015/lib/tp-password-reset/tp-password-reset-request.service.js +100 -0
  99. package/esm2015/lib/tp-password-reset/tp-password-reset-user.service.js +118 -0
  100. package/esm2015/lib/tp-password-reset/tp-password-reset.constants.js +4 -0
  101. package/esm2015/lib/tp-password-reset/tp-password-reset.controller.js +34 -0
  102. package/esm2015/lib/tp-password-reset/tp-password-reset.gql.js +74 -0
  103. package/esm2015/lib/tp-password-reset/tp-password-reset.private.gql.js +165 -0
  104. package/esm2015/lib/tp-password-reset/tp-password-reset.private.service.js +54 -0
  105. package/esm2015/lib/tp-password-reset/tp-password-reset.service.js +92 -0
  106. package/esm2015/lib/tp-password-reset/tp-password-reset.types.js +2 -0
  107. package/esm2015/lib/trusted-party/trusted-party.gql.js +148 -0
  108. package/esm2015/lib/trusted-party/trusted-party.service.js +327 -0
  109. package/esm2015/lib/trusted-party/trusted-party.types.js +41 -0
  110. package/esm2015/lib/trusted-party/trusted-party2.gql.js +64 -0
  111. package/esm2015/lib/trusted-party/trusted-party2.gql.private.js +25 -0
  112. package/esm2015/lib/trusted-party/trusted-party2.service.js +224 -0
  113. package/esm2015/lib/trusted-party/trusted-party2.types.js +2 -0
  114. package/esm2015/lib/two-factor/two-factor.service.js +74 -0
  115. package/esm2015/lib/user/user.gql.js +60 -0
  116. package/esm2015/lib/user/user.service.js +80 -0
  117. package/esm2015/lib/user/user.types.js +2 -0
  118. package/esm2015/lib/web-crypto/web-crypto.service.js +29 -0
  119. package/esm2015/lifeready-core.js +15 -13
  120. package/esm2015/public-api.js +49 -51
  121. package/fesm2015/lifeready-core.js +8764 -8737
  122. package/fesm2015/lifeready-core.js.map +1 -1
  123. package/lib/_common/types.d.ts +3 -1
  124. package/lib/_common/utils.d.ts +2 -2
  125. package/lib/api/lr-apollo.service.d.ts +2 -2
  126. package/lib/api/lr-graphql/lr-graphql.service.d.ts +26 -8
  127. package/lib/api/lr-graphql/lr-merged-mutation.d.ts +22 -4
  128. package/lib/api/lr-graphql/lr-mutation.d.ts +1 -2
  129. package/lib/api/query-processor/common-processors.service.d.ts +1 -1
  130. package/lib/api/query-processor/query-processor.service.d.ts +1 -1
  131. package/lib/api/query-processor/tp-password-reset-processor.service.d.ts +2 -2
  132. package/lib/api/types/lr-graphql.types.d.ts +14 -3
  133. package/lib/auth/auth.gql.d.ts +0 -3
  134. package/lib/auth/auth.types.d.ts +5 -5
  135. package/lib/auth/life-ready-auth.service.d.ts +13 -13
  136. package/lib/category/category.gql.d.ts +1 -1
  137. package/lib/category/category.service.d.ts +3 -3
  138. package/lib/{api → contact-card}/contact-card.service.d.ts +9 -9
  139. package/lib/contact-card/contact-card2.gql.d.ts +25 -0
  140. package/lib/contact-card/contact-card2.service.d.ts +64 -0
  141. package/lib/{cryptography → encryption}/encryption.service.d.ts +10 -9
  142. package/lib/{api/file.service.d.ts → file-upload/file-upload.service.d.ts} +5 -8
  143. package/lib/file-upload/file-upload.types.d.ts +5 -0
  144. package/lib/{auth → idle}/idle.service.d.ts +6 -6
  145. package/lib/{items2 → item2}/item2.gql.d.ts +16 -16
  146. package/lib/{items2 → item2}/item2.service.d.ts +34 -35
  147. package/lib/{cryptography → key}/key-factory.service.d.ts +4 -3
  148. package/lib/{cryptography → key}/key-graph.service.d.ts +6 -6
  149. package/lib/{cryptography → key}/key-meta.service.d.ts +1 -1
  150. package/lib/{cryptography → key}/key.service.d.ts +2 -2
  151. package/lib/{cryptography/cryptography.types.d.ts → key/key.types.d.ts} +13 -17
  152. package/lib/{api → key-exchange}/key-exchange.service.d.ts +5 -5
  153. package/lib/{api → key-exchange}/key-exchange.types.d.ts +4 -4
  154. package/lib/{api → key-exchange}/key-exchange2.gql.d.ts +1 -1
  155. package/lib/{api → key-exchange}/key-exchange2.service.d.ts +82 -29
  156. package/lib/{auth → lbop}/lbop.service.d.ts +7 -7
  157. package/lib/life-ready.config.d.ts +1 -1
  158. package/lib/{api → lock}/lock.gql.d.ts +1 -1
  159. package/lib/{api → lock}/lock.service.d.ts +1 -1
  160. package/lib/message/message.gql.d.ts +13 -0
  161. package/lib/message/message.service.d.ts +36 -0
  162. package/lib/message/message.types.d.ts +12 -0
  163. package/lib/notification/notification.service.d.ts +3 -2
  164. package/lib/password/password.gql.d.ts +3 -0
  165. package/lib/{auth → password}/password.service.d.ts +9 -9
  166. package/lib/{api → persist}/persist.service.d.ts +3 -3
  167. package/lib/plan/plan.service.d.ts +3 -2
  168. package/lib/plan/plan.types.d.ts +2 -1
  169. package/lib/{users → profile}/profile-details.service.d.ts +3 -3
  170. package/lib/{users → profile}/profile.gql.d.ts +2 -2
  171. package/lib/{users → profile}/profile.service.d.ts +6 -6
  172. package/lib/{users → profile}/profile.types.d.ts +3 -2
  173. package/lib/record/record-attachment.service.d.ts +6 -6
  174. package/lib/record/record.service.d.ts +3 -3
  175. package/lib/{auth → register}/register.service.d.ts +4 -4
  176. package/lib/scenario/scenario.controller.d.ts +1 -1
  177. package/lib/scenario/scenario.service.d.ts +105 -5
  178. package/lib/scenario/scenario.types.d.ts +1 -1
  179. package/lib/{api → shared-contact-card}/shared-contact-card.service.d.ts +9 -9
  180. package/lib/{api → shared-contact-card}/shared-contact-card2.gql.d.ts +1 -1
  181. package/lib/{api → shared-contact-card}/shared-contact-card2.service.d.ts +6 -6
  182. package/lib/{cryptography → slip39}/slip39.service.d.ts +0 -1
  183. package/lib/{trusted-parties → tp-assembly}/tp-assembly.d.ts +7 -7
  184. package/lib/{trusted-parties → tp-assembly}/tp-assembly.types.d.ts +3 -3
  185. package/lib/{trusted-parties → tp-password-reset}/tp-password-reset-request.service.d.ts +5 -9
  186. package/lib/{trusted-parties → tp-password-reset}/tp-password-reset-user.service.d.ts +7 -13
  187. package/lib/{trusted-parties → tp-password-reset}/tp-password-reset.controller.d.ts +1 -1
  188. package/lib/tp-password-reset/tp-password-reset.gql.d.ts +63 -0
  189. package/lib/{trusted-parties/tp-password-reset.gql.d.ts → tp-password-reset/tp-password-reset.private.gql.d.ts} +1 -63
  190. package/lib/tp-password-reset/tp-password-reset.private.service.d.ts +59 -0
  191. package/lib/{trusted-parties → tp-password-reset}/tp-password-reset.service.d.ts +6 -89
  192. package/lib/tp-password-reset/tp-password-reset.types.d.ts +40 -0
  193. package/lib/{trusted-parties → trusted-party}/trusted-party.service.d.ts +7 -7
  194. package/lib/{trusted-parties → trusted-party}/trusted-party.types.d.ts +2 -3
  195. package/lib/{trusted-parties → trusted-party}/trusted-party2.gql.d.ts +0 -22
  196. package/lib/trusted-party/trusted-party2.gql.private.d.ts +23 -0
  197. package/lib/{trusted-parties → trusted-party}/trusted-party2.service.d.ts +11 -35
  198. package/lib/trusted-party/trusted-party2.types.d.ts +12 -0
  199. package/lib/{users → user}/user.gql.d.ts +1 -1
  200. package/lib/{users → user}/user.service.d.ts +1 -1
  201. package/lib/{users → user}/user.types.d.ts +1 -1
  202. package/lifeready-core.d.ts +14 -12
  203. package/lifeready-core.metadata.json +1 -1
  204. package/package.json +2 -2
  205. package/public-api.d.ts +48 -50
  206. package/esm2015/lib/api/contact-card.gql.js +0 -79
  207. package/esm2015/lib/api/contact-card.service.js +0 -154
  208. package/esm2015/lib/api/contact-card2.gql.js +0 -60
  209. package/esm2015/lib/api/contact-card2.service.js +0 -103
  210. package/esm2015/lib/api/file.service.js +0 -74
  211. package/esm2015/lib/api/key-exchange.gql.js +0 -188
  212. package/esm2015/lib/api/key-exchange.service.js +0 -442
  213. package/esm2015/lib/api/key-exchange.types.js +0 -7
  214. package/esm2015/lib/api/key-exchange2.gql.js +0 -171
  215. package/esm2015/lib/api/key-exchange2.service.js +0 -480
  216. package/esm2015/lib/api/lock.gql.js +0 -40
  217. package/esm2015/lib/api/lock.service.js +0 -64
  218. package/esm2015/lib/api/message.service.js +0 -138
  219. package/esm2015/lib/api/persist.service.js +0 -181
  220. package/esm2015/lib/api/shared-contact-card.service.js +0 -119
  221. package/esm2015/lib/api/shared-contact-card2.gql.js +0 -41
  222. package/esm2015/lib/api/shared-contact-card2.service.js +0 -117
  223. package/esm2015/lib/api/time.service.js +0 -146
  224. package/esm2015/lib/auth/idle.service.js +0 -168
  225. package/esm2015/lib/auth/idle.types.js +0 -7
  226. package/esm2015/lib/auth/lbop.service.js +0 -355
  227. package/esm2015/lib/auth/password.service.js +0 -315
  228. package/esm2015/lib/auth/register.service.js +0 -172
  229. package/esm2015/lib/auth/two-factor.service.js +0 -74
  230. package/esm2015/lib/cryptography/cryptography.types.js +0 -11
  231. package/esm2015/lib/cryptography/encryption.service.js +0 -189
  232. package/esm2015/lib/cryptography/key-factory.service.js +0 -237
  233. package/esm2015/lib/cryptography/key-graph.service.js +0 -299
  234. package/esm2015/lib/cryptography/key-meta.service.js +0 -200
  235. package/esm2015/lib/cryptography/slip39.service.js +0 -169
  236. package/esm2015/lib/cryptography/web-crypto.service.js +0 -29
  237. package/esm2015/lib/items2/item2.gql.js +0 -127
  238. package/esm2015/lib/items2/item2.gql.private.js +0 -23
  239. package/esm2015/lib/items2/item2.service.js +0 -516
  240. package/esm2015/lib/items2/item2.types.js +0 -1
  241. package/esm2015/lib/scenario/scenario.gql.private.js +0 -198
  242. package/esm2015/lib/trusted-parties/tp-assembly.gql.private.js +0 -22
  243. package/esm2015/lib/trusted-parties/tp-assembly.js +0 -365
  244. package/esm2015/lib/trusted-parties/tp-assembly.types.js +0 -1
  245. package/esm2015/lib/trusted-parties/tp-password-reset-request.service.js +0 -113
  246. package/esm2015/lib/trusted-parties/tp-password-reset-user.service.js +0 -129
  247. package/esm2015/lib/trusted-parties/tp-password-reset.constants.js +0 -4
  248. package/esm2015/lib/trusted-parties/tp-password-reset.controller.js +0 -34
  249. package/esm2015/lib/trusted-parties/tp-password-reset.gql.js +0 -237
  250. package/esm2015/lib/trusted-parties/tp-password-reset.service.js +0 -95
  251. package/esm2015/lib/trusted-parties/trusted-party.gql.js +0 -148
  252. package/esm2015/lib/trusted-parties/trusted-party.service.js +0 -326
  253. package/esm2015/lib/trusted-parties/trusted-party.types.js +0 -41
  254. package/esm2015/lib/trusted-parties/trusted-party2.gql.js +0 -87
  255. package/esm2015/lib/trusted-parties/trusted-party2.service.js +0 -218
  256. package/esm2015/lib/users/profile-details.service.js +0 -214
  257. package/esm2015/lib/users/profile.gql.js +0 -97
  258. package/esm2015/lib/users/profile.service.js +0 -169
  259. package/esm2015/lib/users/profile.types.js +0 -34
  260. package/esm2015/lib/users/user.gql.js +0 -60
  261. package/esm2015/lib/users/user.service.js +0 -79
  262. package/esm2015/lib/users/user.types.js +0 -1
  263. package/lib/api/contact-card2.gql.d.ts +0 -34
  264. package/lib/api/contact-card2.service.d.ts +0 -50
  265. package/lib/api/message.service.d.ts +0 -59
  266. /package/lib/{api → contact-card}/contact-card.gql.d.ts +0 -0
  267. /package/lib/{auth → idle}/idle.types.d.ts +0 -0
  268. /package/lib/{items2 → item2}/item2.gql.private.d.ts +0 -0
  269. /package/lib/{items2 → item2}/item2.types.d.ts +0 -0
  270. /package/lib/{api → key-exchange}/key-exchange.gql.d.ts +0 -0
  271. /package/lib/scenario/{scenario.gql.private.d.ts → scenario.private.gql.d.ts} +0 -0
  272. /package/lib/{api → time}/time.service.d.ts +0 -0
  273. /package/lib/{trusted-parties/tp-assembly.gql.private.d.ts → tp-assembly/tp-assembly.private.gql.d.ts} +0 -0
  274. /package/lib/{trusted-parties → tp-password-reset}/tp-password-reset.constants.d.ts +0 -0
  275. /package/lib/{trusted-parties → trusted-party}/trusted-party.gql.d.ts +0 -0
  276. /package/lib/{auth → two-factor}/two-factor.service.d.ts +0 -0
  277. /package/lib/{cryptography → web-crypto}/web-crypto.service.d.ts +0 -0
@@ -1,7 +1,7 @@
1
1
  import * as lodash from 'lodash';
2
- import { getAliasOrName, getFragments, getMutation, } from '../../_common/ast';
3
2
  import * as ast from '../../_common/ast';
4
- import { fragmentSpreadAstSelection, LrMutationBase } from './lr-mutation-base';
3
+ import { getAliasOrName, getFragments, getMutation, } from '../../_common/ast';
4
+ import { fragmentSpreadAstSelection, LrMutationBase, } from './lr-mutation-base';
5
5
  export class LrMutation extends LrMutationBase {
6
6
  constructor(options) {
7
7
  super();
@@ -45,4 +45,4 @@ export class LrMutation extends LrMutationBase {
45
45
  });
46
46
  }
47
47
  }
48
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibHItbXV0YXRpb24uanMiLCJzb3VyY2VSb290IjoiL29wdC9hdGxhc3NpYW4vcGlwZWxpbmVzL2FnZW50L2J1aWxkL3Byb2plY3RzL2NvcmUvc3JjLyIsInNvdXJjZXMiOlsibGliL2FwaS9sci1ncmFwaHFsL2xyLW11dGF0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxNQUFNLE1BQU0sUUFBUSxDQUFDO0FBR2pDLE9BQU8sRUFDTCxjQUFjLEVBQ2QsWUFBWSxFQUNaLFdBQVcsR0FFWixNQUFNLG1CQUFtQixDQUFDO0FBQzNCLE9BQU8sS0FBSyxHQUFHLE1BQU0sbUJBQW1CLENBQUM7QUFFekMsT0FBTyxFQUFFLDBCQUEwQixFQUFFLGNBQWMsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBRWhGLE1BQU0sT0FBTyxVQUdYLFNBQVEsY0FBNkI7SUFDckMsWUFBWSxPQUFzQztRQUNoRCxLQUFLLEVBQUUsQ0FBQztRQUNSLElBQUksQ0FBQyxRQUFRLEdBQUcsT0FBTyxDQUFDLFFBQVEsQ0FBQztRQUNqQyxJQUFJLENBQUMsU0FBUyxHQUFHLE9BQU8sQ0FBQyxTQUFTLENBQUM7SUFDckMsQ0FBQztJQUVELE1BQU0sQ0FBVSxTQUFxQztRQUNuRCwyQkFBMkI7UUFDM0IsTUFBTSxXQUFXLEdBQUcsTUFBTSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFpQixDQUFDO1FBQ3BFLE1BQU0sWUFBWSxHQUFHLFdBQVcsQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUU5QyxNQUFNLFdBQVcsR0FBRyxFQUErQyxDQUFDO1FBQ3BFLFlBQVksQ0FBQyxTQUFTLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxRQUFnQyxFQUFFLEVBQUU7WUFDbkUsV0FBVyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsUUFBUSxDQUFDO1FBQzlDLENBQUMsQ0FBQyxDQUFDO1FBRUgsTUFBTSxxQkFBcUIsR0FBRyxDQUFDLFNBQW9CLEVBQUUsRUFBRTtZQUNyRCxNQUFNLEtBQUssR0FBRyxTQUFzQixDQUFDO1lBQ3JDLE1BQU0sU0FBUyxHQUFHLGNBQWMsQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUN4QyxNQUFNLFFBQVEsR0FBRyxXQUFXLENBQUMsU0FBUyxDQUFDLENBQUM7WUFFeEMsSUFBSSxDQUFDLFFBQVEsRUFBRTtnQkFDYixPQUFPO2FBQ1I7WUFFRCx3REFBd0Q7WUFDeEQsd0RBQXdEO1lBQ3hELHFEQUFxRDtZQUNyRCxLQUFLLENBQUMsWUFBWSxDQUFDLFVBQVUsR0FBRztnREFFekIsMEJBQTBCLEtBQzdCLElBQUksRUFBRSxHQUFHLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQzthQUU1QixDQUFDO1FBQ0osQ0FBQyxDQUFDO1FBRUYsWUFBWSxDQUFDLFlBQVksQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLENBQUMsU0FBUyxFQUFFLEVBQUU7WUFDekQsSUFBSSxTQUFTLENBQUMsSUFBSSxLQUFLLE9BQU8sRUFBRTtnQkFDOUIscUJBQXFCLENBQUMsU0FBUyxDQUFDLENBQUM7YUFDbEM7UUFDSCxDQUFDLENBQUMsQ0FBQztRQUVILE9BQU8sSUFBSSxVQUFVLENBQUM7WUFDcEIsUUFBUSxFQUFFLGdDQUNMLFdBQVcsS0FDZCxXQUFXLEVBQUU7b0JBQ1gsZ0NBQWdDO29CQUNoQyxHQUFHLFdBQVcsQ0FBQyxXQUFXLENBQUMsTUFBTSxDQUMvQixDQUFDLEdBQUcsRUFBRSxFQUFFLENBQUMsR0FBRyxDQUFDLElBQUksS0FBSyxvQkFBb0IsQ0FDM0M7b0JBQ0QsR0FBRyxTQUFTLENBQUMsV0FBVztpQkFDekIsR0FDNEI7WUFDL0IsU0FBUyxFQUFFLElBQUksQ0FBQyxTQUFTO1NBQzFCLENBQUMsQ0FBQztJQUNMLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGxvZGFzaCBmcm9tICdsb2Rhc2gnO1xuaW1wb3J0IHsgT3BlcmF0aW9uVmFyaWFibGVzIH0gZnJvbSAnQGFwb2xsby9jbGllbnQvY29yZSc7XG5pbXBvcnQgeyBEb2N1bWVudE5vZGUsIEZpZWxkTm9kZSwgRnJhZ21lbnREZWZpbml0aW9uTm9kZSB9IGZyb20gJ2dyYXBocWwnO1xuaW1wb3J0IHtcbiAgZ2V0QWxpYXNPck5hbWUsXG4gIGdldEZyYWdtZW50cyxcbiAgZ2V0TXV0YXRpb24sXG4gIFR5cGVkRG9jdW1lbnROb2RlLFxufSBmcm9tICcuLi8uLi9fY29tbW9uL2FzdCc7XG5pbXBvcnQgKiBhcyBhc3QgZnJvbSAnLi4vLi4vX2NvbW1vbi9hc3QnO1xuaW1wb3J0IHsgTHJNdXRhdGlvbkRhdGEgfSBmcm9tICcuL2xyLW11dGF0aW9uLWJhc2UnO1xuaW1wb3J0IHsgZnJhZ21lbnRTcHJlYWRBc3RTZWxlY3Rpb24sIExyTXV0YXRpb25CYXNlIH0gZnJvbSAnLi9sci1tdXRhdGlvbi1iYXNlJztcblxuZXhwb3J0IGNsYXNzIExyTXV0YXRpb248XG4gIFQgZXh0ZW5kcyBhbnksXG4gIFRWYXJpYWJsZXMgPSBPcGVyYXRpb25WYXJpYWJsZXNcbj4gZXh0ZW5kcyBMck11dGF0aW9uQmFzZTxULCBUVmFyaWFibGVzPiB7XG4gIGNvbnN0cnVjdG9yKG9wdGlvbnM6IExyTXV0YXRpb25EYXRhPFQsIFRWYXJpYWJsZXM+KSB7XG4gICAgc3VwZXIoKTtcbiAgICB0aGlzLm11dGF0aW9uID0gb3B0aW9ucy5tdXRhdGlvbjtcbiAgICB0aGlzLnZhcmlhYmxlcyA9IG9wdGlvbnMudmFyaWFibGVzO1xuICB9XG5cbiAgc2VsZWN0PFRSZXN1bHQ+KGZyYWdtZW50czogVHlwZWREb2N1bWVudE5vZGU8VFJlc3VsdD4pIHtcbiAgICAvLyBEb24ndCB0b3VjaCB0aGUgb3JpZ2luYWxcbiAgICBjb25zdCBtdXRhdGlvbkRvYyA9IGxvZGFzaC5jbG9uZURlZXAodGhpcy5tdXRhdGlvbikgYXMgRG9jdW1lbnROb2RlO1xuICAgIGNvbnN0IG11dGF0aW9uTm9kZSA9IGdldE11dGF0aW9uKG11dGF0aW9uRG9jKTtcblxuICAgIGNvbnN0IGZyYWdtZW50TWFwID0ge30gYXMgeyBba2V5OiBzdHJpbmddOiBGcmFnbWVudERlZmluaXRpb25Ob2RlIH07XG4gICAgZ2V0RnJhZ21lbnRzKGZyYWdtZW50cykuZm9yRWFjaCgoZnJhZ21lbnQ6IEZyYWdtZW50RGVmaW5pdGlvbk5vZGUpID0+IHtcbiAgICAgIGZyYWdtZW50TWFwW2ZyYWdtZW50Lm5hbWUudmFsdWVdID0gZnJhZ21lbnQ7XG4gICAgfSk7XG5cbiAgICBjb25zdCByZXBsYWNlRmllbGRTZWxlY3Rpb24gPSAoc2VsZWN0aW9uOiBGaWVsZE5vZGUpID0+IHtcbiAgICAgIGNvbnN0IGZpZWxkID0gc2VsZWN0aW9uIGFzIEZpZWxkTm9kZTtcbiAgICAgIGNvbnN0IGZpZWxkTmFtZSA9IGdldEFsaWFzT3JOYW1lKGZpZWxkKTtcbiAgICAgIGNvbnN0IGZyYWdtZW50ID0gZnJhZ21lbnRNYXBbZmllbGROYW1lXTtcblxuICAgICAgaWYgKCFmcmFnbWVudCkge1xuICAgICAgICByZXR1cm47XG4gICAgICB9XG5cbiAgICAgIC8vIE1ha2UgdGhlIGVudGlyZSBzZWxlY3Rpb24gb2YgdGhlIG11dGF0aW9uIGEgc3ByZWFkIG9mXG4gICAgICAvLyBhIGZyYWdtZW50IHVzaW5nIHRoZSBzYW1lIG5hbWUgYXMgdGhlIG11dGF0aW9uIGZpZWxkLlxuICAgICAgLy8gV2Ugd2lsbCBhbHNvIHJlbmFtZSB0aGUgZnJhZ21lbnQgdG8gdGhlIHNhbWUgbmFtZS5cbiAgICAgIGZpZWxkLnNlbGVjdGlvblNldC5zZWxlY3Rpb25zID0gW1xuICAgICAgICB7XG4gICAgICAgICAgLi4uZnJhZ21lbnRTcHJlYWRBc3RTZWxlY3Rpb24sXG4gICAgICAgICAgbmFtZTogYXN0Lm5hbWUoZmllbGROYW1lKSxcbiAgICAgICAgfSxcbiAgICAgIF07XG4gICAgfTtcblxuICAgIG11dGF0aW9uTm9kZS5zZWxlY3Rpb25TZXQuc2VsZWN0aW9ucy5mb3JFYWNoKChzZWxlY3Rpb24pID0+IHtcbiAgICAgIGlmIChzZWxlY3Rpb24ua2luZCA9PT0gJ0ZpZWxkJykge1xuICAgICAgICByZXBsYWNlRmllbGRTZWxlY3Rpb24oc2VsZWN0aW9uKTtcbiAgICAgIH1cbiAgICB9KTtcblxuICAgIHJldHVybiBuZXcgTHJNdXRhdGlvbih7XG4gICAgICBtdXRhdGlvbjoge1xuICAgICAgICAuLi5tdXRhdGlvbkRvYyxcbiAgICAgICAgZGVmaW5pdGlvbnM6IFtcbiAgICAgICAgICAvLyBSZW1vdmUgYWxsIGV4aXN0aW5nIGZyYWdtZW50c1xuICAgICAgICAgIC4uLm11dGF0aW9uRG9jLmRlZmluaXRpb25zLmZpbHRlcihcbiAgICAgICAgICAgIChkZWYpID0+IGRlZi5raW5kICE9PSAnRnJhZ21lbnREZWZpbml0aW9uJ1xuICAgICAgICAgICksXG4gICAgICAgICAgLi4uZnJhZ21lbnRzLmRlZmluaXRpb25zLFxuICAgICAgICBdLFxuICAgICAgfSBhcyBUeXBlZERvY3VtZW50Tm9kZTxUUmVzdWx0PixcbiAgICAgIHZhcmlhYmxlczogdGhpcy52YXJpYWJsZXMsXG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibHItbXV0YXRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3NyYy9saWIvYXBpL2xyLWdyYXBocWwvbHItbXV0YXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR0EsT0FBTyxLQUFLLE1BQU0sTUFBTSxRQUFRLENBQUM7QUFDakMsT0FBTyxLQUFLLEdBQUcsTUFBTSxtQkFBbUIsQ0FBQztBQUN6QyxPQUFPLEVBQ0wsY0FBYyxFQUNkLFlBQVksRUFDWixXQUFXLEdBRVosTUFBTSxtQkFBbUIsQ0FBQztBQUMzQixPQUFPLEVBQ0wsMEJBQTBCLEVBQzFCLGNBQWMsR0FFZixNQUFNLG9CQUFvQixDQUFDO0FBRTVCLE1BQU0sT0FBTyxVQUdYLFNBQVEsY0FBNkI7SUFDckMsWUFBWSxPQUFzQztRQUNoRCxLQUFLLEVBQUUsQ0FBQztRQUNSLElBQUksQ0FBQyxRQUFRLEdBQUcsT0FBTyxDQUFDLFFBQVEsQ0FBQztRQUNqQyxJQUFJLENBQUMsU0FBUyxHQUFHLE9BQU8sQ0FBQyxTQUFTLENBQUM7SUFDckMsQ0FBQztJQUVELE1BQU0sQ0FBVSxTQUFxQztRQUNuRCwyQkFBMkI7UUFDM0IsTUFBTSxXQUFXLEdBQUcsTUFBTSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFpQixDQUFDO1FBQ3BFLE1BQU0sWUFBWSxHQUFHLFdBQVcsQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUU5QyxNQUFNLFdBQVcsR0FBRyxFQUErQyxDQUFDO1FBQ3BFLFlBQVksQ0FBQyxTQUFTLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxRQUFnQyxFQUFFLEVBQUU7WUFDbkUsV0FBVyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsUUFBUSxDQUFDO1FBQzlDLENBQUMsQ0FBQyxDQUFDO1FBRUgsTUFBTSxxQkFBcUIsR0FBRyxDQUFDLFNBQW9CLEVBQUUsRUFBRTtZQUNyRCxNQUFNLEtBQUssR0FBRyxTQUFzQixDQUFDO1lBQ3JDLE1BQU0sU0FBUyxHQUFHLGNBQWMsQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUN4QyxNQUFNLFFBQVEsR0FBRyxXQUFXLENBQUMsU0FBUyxDQUFDLENBQUM7WUFFeEMsSUFBSSxDQUFDLFFBQVEsRUFBRTtnQkFDYixPQUFPO2FBQ1I7WUFFRCx3REFBd0Q7WUFDeEQsd0RBQXdEO1lBQ3hELHFEQUFxRDtZQUNyRCxLQUFLLENBQUMsWUFBWSxDQUFDLFVBQVUsR0FBRztnREFFekIsMEJBQTBCLEtBQzdCLElBQUksRUFBRSxHQUFHLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQzthQUU1QixDQUFDO1FBQ0osQ0FBQyxDQUFDO1FBRUYsWUFBWSxDQUFDLFlBQVksQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLENBQUMsU0FBUyxFQUFFLEVBQUU7WUFDekQsSUFBSSxTQUFTLENBQUMsSUFBSSxLQUFLLE9BQU8sRUFBRTtnQkFDOUIscUJBQXFCLENBQUMsU0FBUyxDQUFDLENBQUM7YUFDbEM7UUFDSCxDQUFDLENBQUMsQ0FBQztRQUVILE9BQU8sSUFBSSxVQUFVLENBQUM7WUFDcEIsUUFBUSxFQUFFLGdDQUNMLFdBQVcsS0FDZCxXQUFXLEVBQUU7b0JBQ1gsZ0NBQWdDO29CQUNoQyxHQUFHLFdBQVcsQ0FBQyxXQUFXLENBQUMsTUFBTSxDQUMvQixDQUFDLEdBQUcsRUFBRSxFQUFFLENBQUMsR0FBRyxDQUFDLElBQUksS0FBSyxvQkFBb0IsQ0FDM0M7b0JBQ0QsR0FBRyxTQUFTLENBQUMsV0FBVztpQkFDekIsR0FDNEI7WUFDL0IsU0FBUyxFQUFFLElBQUksQ0FBQyxTQUFTO1NBQzFCLENBQUMsQ0FBQztJQUNMLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnkgKi9cbmltcG9ydCB7IE9wZXJhdGlvblZhcmlhYmxlcyB9IGZyb20gJ0BhcG9sbG8vY2xpZW50L2NvcmUnO1xuaW1wb3J0IHsgRG9jdW1lbnROb2RlLCBGaWVsZE5vZGUsIEZyYWdtZW50RGVmaW5pdGlvbk5vZGUgfSBmcm9tICdncmFwaHFsJztcbmltcG9ydCAqIGFzIGxvZGFzaCBmcm9tICdsb2Rhc2gnO1xuaW1wb3J0ICogYXMgYXN0IGZyb20gJy4uLy4uL19jb21tb24vYXN0JztcbmltcG9ydCB7XG4gIGdldEFsaWFzT3JOYW1lLFxuICBnZXRGcmFnbWVudHMsXG4gIGdldE11dGF0aW9uLFxuICBUeXBlZERvY3VtZW50Tm9kZSxcbn0gZnJvbSAnLi4vLi4vX2NvbW1vbi9hc3QnO1xuaW1wb3J0IHtcbiAgZnJhZ21lbnRTcHJlYWRBc3RTZWxlY3Rpb24sXG4gIExyTXV0YXRpb25CYXNlLFxuICBMck11dGF0aW9uRGF0YSxcbn0gZnJvbSAnLi9sci1tdXRhdGlvbi1iYXNlJztcblxuZXhwb3J0IGNsYXNzIExyTXV0YXRpb248XG4gIFQgZXh0ZW5kcyBhbnksXG4gIFRWYXJpYWJsZXMgPSBPcGVyYXRpb25WYXJpYWJsZXNcbj4gZXh0ZW5kcyBMck11dGF0aW9uQmFzZTxULCBUVmFyaWFibGVzPiB7XG4gIGNvbnN0cnVjdG9yKG9wdGlvbnM6IExyTXV0YXRpb25EYXRhPFQsIFRWYXJpYWJsZXM+KSB7XG4gICAgc3VwZXIoKTtcbiAgICB0aGlzLm11dGF0aW9uID0gb3B0aW9ucy5tdXRhdGlvbjtcbiAgICB0aGlzLnZhcmlhYmxlcyA9IG9wdGlvbnMudmFyaWFibGVzO1xuICB9XG5cbiAgc2VsZWN0PFRSZXN1bHQ+KGZyYWdtZW50czogVHlwZWREb2N1bWVudE5vZGU8VFJlc3VsdD4pIHtcbiAgICAvLyBEb24ndCB0b3VjaCB0aGUgb3JpZ2luYWxcbiAgICBjb25zdCBtdXRhdGlvbkRvYyA9IGxvZGFzaC5jbG9uZURlZXAodGhpcy5tdXRhdGlvbikgYXMgRG9jdW1lbnROb2RlO1xuICAgIGNvbnN0IG11dGF0aW9uTm9kZSA9IGdldE11dGF0aW9uKG11dGF0aW9uRG9jKTtcblxuICAgIGNvbnN0IGZyYWdtZW50TWFwID0ge30gYXMgeyBba2V5OiBzdHJpbmddOiBGcmFnbWVudERlZmluaXRpb25Ob2RlIH07XG4gICAgZ2V0RnJhZ21lbnRzKGZyYWdtZW50cykuZm9yRWFjaCgoZnJhZ21lbnQ6IEZyYWdtZW50RGVmaW5pdGlvbk5vZGUpID0+IHtcbiAgICAgIGZyYWdtZW50TWFwW2ZyYWdtZW50Lm5hbWUudmFsdWVdID0gZnJhZ21lbnQ7XG4gICAgfSk7XG5cbiAgICBjb25zdCByZXBsYWNlRmllbGRTZWxlY3Rpb24gPSAoc2VsZWN0aW9uOiBGaWVsZE5vZGUpID0+IHtcbiAgICAgIGNvbnN0IGZpZWxkID0gc2VsZWN0aW9uIGFzIEZpZWxkTm9kZTtcbiAgICAgIGNvbnN0IGZpZWxkTmFtZSA9IGdldEFsaWFzT3JOYW1lKGZpZWxkKTtcbiAgICAgIGNvbnN0IGZyYWdtZW50ID0gZnJhZ21lbnRNYXBbZmllbGROYW1lXTtcblxuICAgICAgaWYgKCFmcmFnbWVudCkge1xuICAgICAgICByZXR1cm47XG4gICAgICB9XG5cbiAgICAgIC8vIE1ha2UgdGhlIGVudGlyZSBzZWxlY3Rpb24gb2YgdGhlIG11dGF0aW9uIGEgc3ByZWFkIG9mXG4gICAgICAvLyBhIGZyYWdtZW50IHVzaW5nIHRoZSBzYW1lIG5hbWUgYXMgdGhlIG11dGF0aW9uIGZpZWxkLlxuICAgICAgLy8gV2Ugd2lsbCBhbHNvIHJlbmFtZSB0aGUgZnJhZ21lbnQgdG8gdGhlIHNhbWUgbmFtZS5cbiAgICAgIGZpZWxkLnNlbGVjdGlvblNldC5zZWxlY3Rpb25zID0gW1xuICAgICAgICB7XG4gICAgICAgICAgLi4uZnJhZ21lbnRTcHJlYWRBc3RTZWxlY3Rpb24sXG4gICAgICAgICAgbmFtZTogYXN0Lm5hbWUoZmllbGROYW1lKSxcbiAgICAgICAgfSxcbiAgICAgIF07XG4gICAgfTtcblxuICAgIG11dGF0aW9uTm9kZS5zZWxlY3Rpb25TZXQuc2VsZWN0aW9ucy5mb3JFYWNoKChzZWxlY3Rpb24pID0+IHtcbiAgICAgIGlmIChzZWxlY3Rpb24ua2luZCA9PT0gJ0ZpZWxkJykge1xuICAgICAgICByZXBsYWNlRmllbGRTZWxlY3Rpb24oc2VsZWN0aW9uKTtcbiAgICAgIH1cbiAgICB9KTtcblxuICAgIHJldHVybiBuZXcgTHJNdXRhdGlvbih7XG4gICAgICBtdXRhdGlvbjoge1xuICAgICAgICAuLi5tdXRhdGlvbkRvYyxcbiAgICAgICAgZGVmaW5pdGlvbnM6IFtcbiAgICAgICAgICAvLyBSZW1vdmUgYWxsIGV4aXN0aW5nIGZyYWdtZW50c1xuICAgICAgICAgIC4uLm11dGF0aW9uRG9jLmRlZmluaXRpb25zLmZpbHRlcihcbiAgICAgICAgICAgIChkZWYpID0+IGRlZi5raW5kICE9PSAnRnJhZ21lbnREZWZpbml0aW9uJ1xuICAgICAgICAgICksXG4gICAgICAgICAgLi4uZnJhZ21lbnRzLmRlZmluaXRpb25zLFxuICAgICAgICBdLFxuICAgICAgfSBhcyBUeXBlZERvY3VtZW50Tm9kZTxUUmVzdWx0PixcbiAgICAgIHZhcmlhYmxlczogdGhpcy52YXJpYWJsZXMsXG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
@@ -15,4 +15,4 @@ export class LrService {
15
15
  });
16
16
  }
17
17
  }
18
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibHIuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIvb3B0L2F0bGFzc2lhbi9waXBlbGluZXMvYWdlbnQvYnVpbGQvcHJvamVjdHMvY29yZS9zcmMvIiwic291cmNlcyI6WyJsaWIvYXBpL2xyLWdyYXBocWwvbHIuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQ0EsT0FBTyxFQUNMLGdCQUFnQixHQUdqQixNQUFNLHNCQUFzQixDQUFDO0FBRzlCLE1BQU0sT0FBTyxTQUFTO0lBR3BCLFlBQVksUUFBa0I7UUFDNUIsSUFBSSxDQUFDLFNBQVMsR0FBRyxRQUFRLENBQUMsR0FBRyxDQUFDLGdCQUFnQixDQUFDLENBQUM7SUFDbEQsQ0FBQztJQUVlLE1BQU0sQ0FDcEIsVUFFMEMsRUFDMUMsT0FBMEM7O1lBRTFDLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsVUFBVSxFQUFFLE9BQU8sQ0FBQyxDQUFDO1FBQ3RELENBQUM7S0FBQTtJQUVlLEtBQUssQ0FBTyxPQUE2Qjs7WUFDdkQsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUN2QyxDQUFDO0tBQUE7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdG9yIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1xuICBMckdyYXBoUUxTZXJ2aWNlLFxuICBMck11dGF0aW9uT3B0aW9ucyxcbiAgTHJRdWVyeU9wdGlvbnMsXG59IGZyb20gJy4vbHItZ3JhcGhxbC5zZXJ2aWNlJztcbmltcG9ydCB7IExyTXV0YXRpb25CYXNlIH0gZnJvbSAnLi9sci1tdXRhdGlvbi1iYXNlJztcblxuZXhwb3J0IGNsYXNzIExyU2VydmljZSB7XG4gIHByb3RlY3RlZCBsckdyYXBoUUw6IExyR3JhcGhRTFNlcnZpY2U7XG5cbiAgY29uc3RydWN0b3IoaW5qZWN0b3I6IEluamVjdG9yKSB7XG4gICAgdGhpcy5sckdyYXBoUUwgPSBpbmplY3Rvci5nZXQoTHJHcmFwaFFMU2VydmljZSk7XG4gIH1cblxuICBwcm90ZWN0ZWQgYXN5bmMgbXV0YXRlPFQsIFRWYXJpYWJsZXM+KFxuICAgIGxyTXV0YXRpb246XG4gICAgICB8IExyTXV0YXRpb25CYXNlPFQsIFRWYXJpYWJsZXM+XG4gICAgICB8IFByb21pc2U8THJNdXRhdGlvbkJhc2U8VCwgVFZhcmlhYmxlcz4+LFxuICAgIG9wdGlvbnM/OiBMck11dGF0aW9uT3B0aW9uczxULCBUVmFyaWFibGVzPlxuICApIHtcbiAgICByZXR1cm4gdGhpcy5sckdyYXBoUUwubHJNdXRhdGUobHJNdXRhdGlvbiwgb3B0aW9ucyk7XG4gIH1cblxuICBwcm90ZWN0ZWQgYXN5bmMgcXVlcnk8VCwgVj4ob3B0aW9uczogTHJRdWVyeU9wdGlvbnM8VCwgVj4pIHtcbiAgICByZXR1cm4gdGhpcy5sckdyYXBoUUwucXVlcnkob3B0aW9ucyk7XG4gIH1cbn1cbiJdfQ==
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibHIuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvc3JjL2xpYi9hcGkvbHItZ3JhcGhxbC9sci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFDQSxPQUFPLEVBQ0wsZ0JBQWdCLEdBR2pCLE1BQU0sc0JBQXNCLENBQUM7QUFHOUIsTUFBTSxPQUFPLFNBQVM7SUFHcEIsWUFBWSxRQUFrQjtRQUM1QixJQUFJLENBQUMsU0FBUyxHQUFHLFFBQVEsQ0FBQyxHQUFHLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztJQUNsRCxDQUFDO0lBRWUsTUFBTSxDQUNwQixVQUUwQyxFQUMxQyxPQUEwQzs7WUFFMUMsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxVQUFVLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFDdEQsQ0FBQztLQUFBO0lBRWUsS0FBSyxDQUFPLE9BQTZCOztZQUN2RCxPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ3ZDLENBQUM7S0FBQTtDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0b3IgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7XG4gIExyR3JhcGhRTFNlcnZpY2UsXG4gIExyTXV0YXRpb25PcHRpb25zLFxuICBMclF1ZXJ5T3B0aW9ucyxcbn0gZnJvbSAnLi9sci1ncmFwaHFsLnNlcnZpY2UnO1xuaW1wb3J0IHsgTHJNdXRhdGlvbkJhc2UgfSBmcm9tICcuL2xyLW11dGF0aW9uLWJhc2UnO1xuXG5leHBvcnQgY2xhc3MgTHJTZXJ2aWNlIHtcbiAgcHJvdGVjdGVkIGxyR3JhcGhRTDogTHJHcmFwaFFMU2VydmljZTtcblxuICBjb25zdHJ1Y3RvcihpbmplY3RvcjogSW5qZWN0b3IpIHtcbiAgICB0aGlzLmxyR3JhcGhRTCA9IGluamVjdG9yLmdldChMckdyYXBoUUxTZXJ2aWNlKTtcbiAgfVxuXG4gIHByb3RlY3RlZCBhc3luYyBtdXRhdGU8VCwgVFZhcmlhYmxlcz4oXG4gICAgbHJNdXRhdGlvbjpcbiAgICAgIHwgTHJNdXRhdGlvbkJhc2U8VCwgVFZhcmlhYmxlcz5cbiAgICAgIHwgUHJvbWlzZTxMck11dGF0aW9uQmFzZTxULCBUVmFyaWFibGVzPj4sXG4gICAgb3B0aW9ucz86IExyTXV0YXRpb25PcHRpb25zPFQsIFRWYXJpYWJsZXM+XG4gICkge1xuICAgIHJldHVybiB0aGlzLmxyR3JhcGhRTC5sck11dGF0ZShsck11dGF0aW9uLCBvcHRpb25zKTtcbiAgfVxuXG4gIHByb3RlY3RlZCBhc3luYyBxdWVyeTxULCBWPihvcHRpb25zOiBMclF1ZXJ5T3B0aW9uczxULCBWPikge1xuICAgIHJldHVybiB0aGlzLmxyR3JhcGhRTC5xdWVyeShvcHRpb25zKTtcbiAgfVxufVxuIl19
@@ -1,10 +1,11 @@
1
1
  import { __awaiter, __decorate } from "tslib";
2
+ /* eslint-disable @typescript-eslint/no-explicit-any */
2
3
  import { Injectable, NgZone } from '@angular/core';
3
- import { KeyGraphService } from '../../cryptography/key-graph.service';
4
+ import { KeyGraphService } from '../../key/key-graph.service';
4
5
  import { LrBadLogicException } from '../../_common/exceptions';
5
6
  import { RunOutsideAngular } from '../../_common/run-outside-angular';
6
7
  import * as i0 from "@angular/core";
7
- import * as i1 from "../../cryptography/key-graph.service";
8
+ import * as i1 from "../../key/key-graph.service";
8
9
  export const DefaultProcessorOptions = {
9
10
  hasKeys: true,
10
11
  };
@@ -90,4 +91,4 @@ CommonProcessorsService = __decorate([
90
91
  })
91
92
  ], CommonProcessorsService);
92
93
  export { CommonProcessorsService };
93
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"common-processors.service.js","sourceRoot":"/opt/atlassian/pipelines/agent/build/projects/core/src/","sources":["lib/api/query-processor/common-processors.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, NgZone } from '@angular/core';\nimport { EncryptionService } from '../../cryptography/encryption.service';\nimport { KeyGraphService } from '../../cryptography/key-graph.service';\nimport { LrBadLogicException } from '../../_common/exceptions';\nimport { RunOutsideAngular } from '../../_common/run-outside-angular';\nimport { Connection } from '../types';\n\nexport interface ProcessorOptions {\n  hasKeys: boolean;\n}\n\nexport const DefaultProcessorOptions: ProcessorOptions = {\n  hasKeys: true,\n};\n\n// Sent to each processor for context information\nexport interface ProcessorContext {\n  path: ReadonlyArray<string>;\n  // processor can set this to false if child fields should\n  // not be processed any further\n  processChildren: boolean;\n}\n\nexport interface ProcessorCallbackParams<T = any> {\n  field: T;\n  context: ProcessorContext;\n  options: ProcessorOptions;\n}\n\nexport type ProcessorCallback<T = any> = (\n  params: ProcessorCallbackParams<T>\n) => T | Promise<T>;\n\ninterface ParseJsonProcessorOptions {\n  plainFieldName?: string;\n  jsonFieldSuffix?: string;\n}\n\ninterface DecryptionProcessorOptions {\n  cipherFieldName?: string;\n  clearFieldSuffix?: string;\n  getKeyId?: (params: ProcessorCallbackParams) => Promise<string> | string;\n}\n\nexport async function processConnection<Node>(\n  field: Connection<Node>,\n  processNode: (node: Node) => Node | Promise<Node>\n): Promise<Connection<Node>> {\n  return {\n    ...field,\n    edges: await Promise.all(\n      field.edges.map(async (edge) => ({\n        ...edge,\n        node: await processNode(edge.node),\n      }))\n    ),\n  };\n}\n\n@RunOutsideAngular({\n  ngZoneName: 'ngZone',\n})\n@Injectable({\n  providedIn: 'root',\n})\nexport class CommonProcessorsService {\n  constructor(private ngZone: NgZone, private keyGraph: KeyGraphService) {}\n\n  series(processors: ProcessorCallback[]): ProcessorCallback {\n    return async ({ field, context, options }) => {\n      for (const processor of processors) {\n        field = await processor({ field, context, options });\n      }\n      return field;\n    };\n  }\n\n  makeJsonParseProcessor({\n    plainFieldName,\n    jsonFieldSuffix = 'Json',\n  }: ParseJsonProcessorOptions = {}): ProcessorCallback {\n    const jsonFieldName = plainFieldName + jsonFieldSuffix;\n\n    return ({ field }) => {\n      if (field[plainFieldName] == null || jsonFieldName in field) {\n        // if plainFieldName is undefined or null, then don't parse it.\n        // if you parse it, then JSON.parse(null) and JSON.parse(\"null\") both return null, so\n        // you can't distinguish between the two.\n        // If clearFieldName already exists in node as a property, then we don't\n        // need to process it again, even if it's value can be undefined or null even.\n        return field;\n      }\n\n      try {\n        return {\n          ...field,\n          [jsonFieldName]: JSON.parse(field[plainFieldName]),\n        };\n      } catch (error) {\n        return field;\n      }\n    };\n  }\n\n  makeDecryptionProcessor({\n    cipherFieldName,\n    clearFieldSuffix = 'ClearJson',\n    getKeyId = null,\n  }: DecryptionProcessorOptions = {}): ProcessorCallback {\n    const clearFieldName = cipherFieldName + clearFieldSuffix;\n\n    return async (params) => {\n      const { field, context, options } = params;\n\n      // Can't decrypt anything if key graph is not returned\n      if (!options.hasKeys) {\n        return field;\n      }\n\n      const cipherField = field[cipherFieldName];\n\n      // cipherField can be empty string, null or undefined.\n      if (!cipherField || clearFieldName in field) {\n        return field;\n      }\n\n      const keyId = getKeyId\n        ? await getKeyId(params)\n        : field.keyId || field.key?.id;\n\n      if (!keyId) {\n        const keyIdName = getKeyId ? 'key-id' : 'keyId or key.id';\n        throw new LrBadLogicException(\n          `Query response does not contain ${keyIdName} field: ${context.path.join(\n            '.'\n          )}`\n        );\n      }\n\n      return this.keyGraph\n        .decryptFromString(keyId, cipherField)\n        .then((clear) => ({\n          ...field,\n          [clearFieldName]: clear,\n        }));\n    };\n  }\n}\n"]}
94
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"common-processors.service.js","sourceRoot":"","sources":["../../../../../../../projects/core/src/lib/api/query-processor/common-processors.service.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { Injectable, NgZone } from '@angular/core';\nimport { KeyGraphService } from '../../key/key-graph.service';\nimport { LrBadLogicException } from '../../_common/exceptions';\nimport { RunOutsideAngular } from '../../_common/run-outside-angular';\nimport { Connection } from '../types';\n\nexport interface ProcessorOptions {\n  hasKeys: boolean;\n}\n\nexport const DefaultProcessorOptions: ProcessorOptions = {\n  hasKeys: true,\n};\n\n// Sent to each processor for context information\nexport interface ProcessorContext {\n  path: ReadonlyArray<string>;\n  // processor can set this to false if child fields should\n  // not be processed any further\n  processChildren: boolean;\n}\n\nexport interface ProcessorCallbackParams<T = any> {\n  field: T;\n  context: ProcessorContext;\n  options: ProcessorOptions;\n}\n\nexport type ProcessorCallback<T = any> = (\n  params: ProcessorCallbackParams<T>\n) => T | Promise<T>;\n\ninterface ParseJsonProcessorOptions {\n  plainFieldName?: string;\n  jsonFieldSuffix?: string;\n}\n\ninterface DecryptionProcessorOptions {\n  cipherFieldName?: string;\n  clearFieldSuffix?: string;\n  getKeyId?: (params: ProcessorCallbackParams) => Promise<string> | string;\n}\n\nexport async function processConnection<Node>(\n  field: Connection<Node>,\n  processNode: (node: Node) => Node | Promise<Node>\n): Promise<Connection<Node>> {\n  return {\n    ...field,\n    edges: await Promise.all(\n      field.edges.map(async (edge) => ({\n        ...edge,\n        node: await processNode(edge.node),\n      }))\n    ),\n  };\n}\n\n@RunOutsideAngular({\n  ngZoneName: 'ngZone',\n})\n@Injectable({\n  providedIn: 'root',\n})\nexport class CommonProcessorsService {\n  constructor(private ngZone: NgZone, private keyGraph: KeyGraphService) {}\n\n  series(processors: ProcessorCallback[]): ProcessorCallback {\n    return async ({ field, context, options }) => {\n      for (const processor of processors) {\n        field = await processor({ field, context, options });\n      }\n      return field;\n    };\n  }\n\n  makeJsonParseProcessor({\n    plainFieldName,\n    jsonFieldSuffix = 'Json',\n  }: ParseJsonProcessorOptions = {}): ProcessorCallback {\n    const jsonFieldName = plainFieldName + jsonFieldSuffix;\n\n    return ({ field }) => {\n      if (field[plainFieldName] == null || jsonFieldName in field) {\n        // if plainFieldName is undefined or null, then don't parse it.\n        // if you parse it, then JSON.parse(null) and JSON.parse(\"null\") both return null, so\n        // you can't distinguish between the two.\n        // If clearFieldName already exists in node as a property, then we don't\n        // need to process it again, even if it's value can be undefined or null even.\n        return field;\n      }\n\n      try {\n        return {\n          ...field,\n          [jsonFieldName]: JSON.parse(field[plainFieldName]),\n        };\n      } catch (error) {\n        return field;\n      }\n    };\n  }\n\n  makeDecryptionProcessor({\n    cipherFieldName,\n    clearFieldSuffix = 'ClearJson',\n    getKeyId = null,\n  }: DecryptionProcessorOptions = {}): ProcessorCallback {\n    const clearFieldName = cipherFieldName + clearFieldSuffix;\n\n    return async (params) => {\n      const { field, context, options } = params;\n\n      // Can't decrypt anything if key graph is not returned\n      if (!options.hasKeys) {\n        return field;\n      }\n\n      const cipherField = field[cipherFieldName];\n\n      // cipherField can be empty string, null or undefined.\n      if (!cipherField || clearFieldName in field) {\n        return field;\n      }\n\n      const keyId = getKeyId\n        ? await getKeyId(params)\n        : field.keyId || field.key?.id;\n\n      if (!keyId) {\n        const keyIdName = getKeyId ? 'key-id' : 'keyId or key.id';\n        throw new LrBadLogicException(\n          `Query response does not contain ${keyIdName} field: ${context.path.join(\n            '.'\n          )}`\n        );\n      }\n\n      return this.keyGraph\n        .decryptFromString(keyId, cipherField)\n        .then((clear) => ({\n          ...field,\n          [clearFieldName]: clear,\n        }));\n    };\n  }\n}\n"]}
@@ -1,3 +1,3 @@
1
1
  export * from './query-processor.service';
2
2
  export * from './common-processors.service';
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiL29wdC9hdGxhc3NpYW4vcGlwZWxpbmVzL2FnZW50L2J1aWxkL3Byb2plY3RzL2NvcmUvc3JjLyIsInNvdXJjZXMiOlsibGliL2FwaS9xdWVyeS1wcm9jZXNzb3IvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLDZCQUE2QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9xdWVyeS1wcm9jZXNzb3Iuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1vbi1wcm9jZXNzb3JzLnNlcnZpY2UnO1xuIl19
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3NyYy9saWIvYXBpL3F1ZXJ5LXByb2Nlc3Nvci9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsNkJBQTZCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3F1ZXJ5LXByb2Nlc3Nvci5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vY29tbW9uLXByb2Nlc3NvcnMuc2VydmljZSc7XG4iXX0=
@@ -1,13 +1,14 @@
1
1
  import { __awaiter, __decorate } from "tslib";
2
+ /* eslint-disable @typescript-eslint/no-explicit-any */
2
3
  import { Injectable, NgZone } from '@angular/core';
4
+ import { KeyService } from '../../key/key.service';
3
5
  import { LrBadLogicException } from '../../_common/exceptions';
6
+ import { RunOutsideAngular } from '../../_common/run-outside-angular';
4
7
  import { mapValuesMayAsync, promiseAllMayAsync } from '../../_common/utils';
5
- import { KeyService } from '../../cryptography/key.service';
6
8
  import { CommonProcessorsService, DefaultProcessorOptions, } from './common-processors.service';
7
- import { RunOutsideAngular } from '../../_common/run-outside-angular';
8
9
  import { TpPasswordResetProcessorService } from './tp-password-reset-processor.service';
9
10
  import * as i0 from "@angular/core";
10
- import * as i1 from "../../cryptography/key.service";
11
+ import * as i1 from "../../key/key.service";
11
12
  import * as i2 from "./common-processors.service";
12
13
  import * as i3 from "./tp-password-reset-processor.service";
13
14
  function extendPath(context, key) {
@@ -259,4 +260,4 @@ QueryProcessorService = __decorate([
259
260
  })
260
261
  ], QueryProcessorService);
261
262
  export { QueryProcessorService };
262
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"query-processor.service.js","sourceRoot":"/opt/atlassian/pipelines/agent/build/projects/core/src/","sources":["lib/api/query-processor/query-processor.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, NgZone } from '@angular/core';\nimport { LrBadLogicException } from '../../_common/exceptions';\nimport { mapValuesMayAsync, promiseAllMayAsync } from '../../_common/utils';\nimport { KeyService } from '../../cryptography/key.service';\nimport {\n  CommonProcessorsService,\n  // FieldContext,\n  ProcessorCallback,\n  ProcessorCallbackParams,\n  ProcessorContext,\n  ProcessorOptions,\n  DefaultProcessorOptions,\n} from './common-processors.service';\nimport { TpPasswordResetService } from '../../trusted-parties/tp-password-reset.service';\nimport { RunOutsideAngular } from '../../_common/run-outside-angular';\nimport { TpPasswordResetProcessorService } from './tp-password-reset-processor.service';\n\nfunction extendPath(context: ProcessorContext, key: string): ProcessorContext {\n  return {\n    ...context,\n    path: [...context.path, key],\n  };\n}\n\n@RunOutsideAngular({\n  ngZoneName: 'ngZone',\n})\n@Injectable({\n  providedIn: 'root',\n})\nexport class QueryProcessorService {\n  readonly TYPENAME = '__typename';\n  private processors: { [key: string]: ProcessorCallback } = {};\n\n  async processQuery(\n    fields: { [key: string]: any },\n    options: ProcessorOptions\n  ) {\n    options = {\n      ...DefaultProcessorOptions,\n      ...options,\n    };\n\n    // The top level query does not have __typename\n    const ret = mapValuesMayAsync(fields, (field, key) =>\n      this.processField({\n        field,\n        context: {\n          path: [key],\n          processChildren: true,\n        },\n        options,\n      })\n    );\n    return ret;\n  }\n\n  // Either returns a Promise, or a value.\n  // The Promise<any> type is redundant but it shows that it can return a promise\n  // We are not using async on the function because we don't want auto promotion into a Promise, which\n  // always defer execution into the event loops. It is costly and unnecessary for objects\n  // with only native data types.\n  private async processField({\n    field,\n    context,\n    options,\n  }: ProcessorCallbackParams) {\n    if (field?.then) {\n      throw new LrBadLogicException(\n        'processField() should not receive thenable.'\n      );\n    }\n\n    if (field == null) {\n      return null;\n    }\n\n    const newParams: ProcessorCallbackParams = {\n      field,\n      context: {\n        ...context,\n        // Processors modifies this field to communicate back to the caller.\n        processChildren: true,\n      },\n      options,\n    };\n\n    // TODO allow registering processors by field name so we can process primitive fields as well.\n    // We have common fields like \"created\", \"modified\" that be processed based on name.\n    if (field[this.TYPENAME]) {\n      // It's a custom object type\n      const processor = this.processors[field[this.TYPENAME]];\n      if (processor) {\n        // Returns either a value or a promise.\n        field = processor(newParams);\n      }\n\n      const processChildren = (childField) => {\n        if (\n          context.processChildren &&\n          childField !== null &&\n          typeof childField === 'object'\n        ) {\n          return mapValuesMayAsync(childField, (x, key) =>\n            this.processField({\n              field: x,\n              context: extendPath(context, key),\n              options,\n            })\n          );\n        } else {\n          return childField;\n        }\n      };\n\n      // Keep processing all child fields\n      if (field.then) {\n        // Wait for field to resolve\n        field = field.then((resolvedField) => {\n          return processChildren(resolvedField);\n        });\n      } else {\n        // Field is already resolved\n        field = processChildren(field);\n      }\n    } else {\n      // Keep processing all child fields\n      if (context.processChildren) {\n        if (Array.isArray(field)) {\n          field = promiseAllMayAsync(\n            (field as Array<any>).map((x, i) =>\n              this.processField({\n                field: x,\n                context: extendPath(context, i.toString()),\n                options,\n              })\n            )\n          );\n        }\n      }\n    }\n\n    return field;\n  }\n\n  private registerProcessor(name: string, processor: ProcessorCallback) {\n    if (this.processors[name]) {\n      throw new LrBadLogicException(\n        `Processor for field ${name} already exists.`\n      );\n    }\n    this.processors[name] = processor;\n  }\n\n  constructor(\n    private ngZone: NgZone,\n    private keyService: KeyService,\n    private common: CommonProcessorsService,\n    private tpprProcessor: TpPasswordResetProcessorService\n  ) {\n    this.registerProcessor(\n      'DirectoryNode',\n      common.series([\n        common.makeJsonParseProcessor({\n          plainFieldName: 'plainMeta',\n        }),\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'cipherMeta',\n        }),\n      ])\n    );\n    this.registerProcessor(\n      'FileStateNode',\n      common.series([\n        common.makeJsonParseProcessor({\n          plainFieldName: 'plainMeta',\n        }),\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'cipherMeta',\n        }),\n      ])\n    );\n    this.registerProcessor(\n      'ContactCardNode',\n      common.makeDecryptionProcessor({\n        cipherFieldName: 'cipherData',\n      })\n    );\n    this.registerProcessor(\n      'SharedContactCardNode',\n      common.series([\n        common.makeJsonParseProcessor({\n          plainFieldName: 'ownerPlainData',\n        }),\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'ownerCipherData',\n          getKeyId: ({ field }) => {\n            return field.ownerKey.id;\n          },\n        }),\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'receiverCipherData',\n          getKeyId: ({ field }) => {\n            return field.receiverKey.id;\n          },\n        }),\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'sharedCipherData',\n          getKeyId: ({ field }) => field.sharedKey.id,\n        }),\n      ])\n    );\n    this.registerProcessor(\n      'TpPasswordResetNode',\n      this.tpprProcessor.makeTpPasswordResetNodeProcessor()\n    );\n    this.registerProcessor(\n      'SharedTpClaimApproverNode',\n      common.series([\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'sharedCipherApprovalData',\n          getKeyId: ({ field }) => field.sharedKey.id,\n        }),\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'sharedCipherPartialAssemblyKey',\n          getKeyId: ({ field }) => field.sharedKey.id,\n        }),\n      ])\n    );\n    this.registerProcessor(\n      'TpAssemblyAsApproverNode',\n      common.series([\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'sharedCipherData',\n          getKeyId: ({ field }) => field.sharedKey.id,\n        }),\n      ])\n    );\n    this.registerProcessor(\n      'ScenarioNode',\n      common.series([\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'subjectCipherData',\n          getKeyId: ({ field }) => field.subjectKey.id,\n        }),\n      ])\n    );\n    this.registerProcessor(\n      'ScenarioReceiverNode',\n      common.series([\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'sharedCipherData',\n          getKeyId: ({ field }) => field.sharedKey.id,\n        }),\n      ])\n    );\n    this.registerProcessor(\n      'ScenarioReceiverDirectoryNode',\n      common.series([\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'sharedCipherData',\n          getKeyId: ({ field }) => field.sharedKey.id,\n        }),\n      ])\n    );\n    this.registerProcessor(\n      'ScenarioApproverAssemblyNode',\n      common.series([\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'assemblyCipherData',\n          getKeyId: ({ field }) => field.assemblyKey.id,\n        }),\n      ])\n    );\n    this.registerProcessor(\n      'ScenarioApproverSubAssemblyNode',\n      common.series([\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'subjectCipherData',\n          getKeyId: ({ field }) => field.subjectKey.id,\n        }),\n      ])\n    );\n    this.registerProcessor(\n      'ScenarioApproverNode',\n      common.series([\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'sharedCipherData',\n          getKeyId: ({ field }) => field.sharedKey.id,\n        }),\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'sharedCipherApprovalData',\n          getKeyId: ({ field }) => field.sharedKey.id,\n        }),\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'sharedCipherPartialAssemblyKey',\n          getKeyId: ({ field }) => field.sharedKey.id,\n        }),\n      ])\n    );\n    this.registerProcessor(\n      'ScenarioClaimantNode',\n      common.series([\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'sharedCipherData',\n          getKeyId: ({ field }) => field.sharedKey.id,\n        }),\n      ])\n    );\n    this.registerProcessor(\n      'TpAssemblyNode',\n      common.series([\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'subjectCipherData',\n          getKeyId: ({ field }) => field.subjectKey.id,\n        }),\n      ])\n    );\n    this.registerProcessor(\n      'TpSubAssemblyNode',\n      common.series([\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'subjectCipherData',\n          getKeyId: ({ field }) => field.subjectKey.id,\n        }),\n      ])\n    );\n    this.registerProcessor(\n      'NotificationNode',\n      common.series([\n        common.makeJsonParseProcessor({\n          plainFieldName: 'plainMeta',\n        }),\n        common.makeJsonParseProcessor({\n          plainFieldName: 'plainData',\n        }),\n      ])\n    );\n  }\n}\n"]}
263
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"query-processor.service.js","sourceRoot":"","sources":["../../../../../../../projects/core/src/lib/api/query-processor/query-processor.service.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { Injectable, NgZone } from '@angular/core';\nimport { KeyService } from '../../key/key.service';\nimport { LrBadLogicException } from '../../_common/exceptions';\nimport { RunOutsideAngular } from '../../_common/run-outside-angular';\nimport { mapValuesMayAsync, promiseAllMayAsync } from '../../_common/utils';\nimport {\n  CommonProcessorsService,\n  DefaultProcessorOptions,\n  // FieldContext,\n  ProcessorCallback,\n  ProcessorCallbackParams,\n  ProcessorContext,\n  ProcessorOptions,\n} from './common-processors.service';\nimport { TpPasswordResetProcessorService } from './tp-password-reset-processor.service';\n\nfunction extendPath(context: ProcessorContext, key: string): ProcessorContext {\n  return {\n    ...context,\n    path: [...context.path, key],\n  };\n}\n\n@RunOutsideAngular({\n  ngZoneName: 'ngZone',\n})\n@Injectable({\n  providedIn: 'root',\n})\nexport class QueryProcessorService {\n  readonly TYPENAME = '__typename';\n  private processors: { [key: string]: ProcessorCallback } = {};\n\n  async processQuery(\n    fields: { [key: string]: any },\n    options: ProcessorOptions\n  ) {\n    options = {\n      ...DefaultProcessorOptions,\n      ...options,\n    };\n\n    // The top level query does not have __typename\n    const ret = mapValuesMayAsync(fields, (field, key) =>\n      this.processField({\n        field,\n        context: {\n          path: [key],\n          processChildren: true,\n        },\n        options,\n      })\n    );\n    return ret;\n  }\n\n  // Either returns a Promise, or a value.\n  // The Promise<any> type is redundant but it shows that it can return a promise\n  // We are not using async on the function because we don't want auto promotion into a Promise, which\n  // always defer execution into the event loops. It is costly and unnecessary for objects\n  // with only native data types.\n  private async processField({\n    field,\n    context,\n    options,\n  }: ProcessorCallbackParams) {\n    if (field?.then) {\n      throw new LrBadLogicException(\n        'processField() should not receive thenable.'\n      );\n    }\n\n    if (field == null) {\n      return null;\n    }\n\n    const newParams: ProcessorCallbackParams = {\n      field,\n      context: {\n        ...context,\n        // Processors modifies this field to communicate back to the caller.\n        processChildren: true,\n      },\n      options,\n    };\n\n    // TODO allow registering processors by field name so we can process primitive fields as well.\n    // We have common fields like \"created\", \"modified\" that be processed based on name.\n    if (field[this.TYPENAME]) {\n      // It's a custom object type\n      const processor = this.processors[field[this.TYPENAME]];\n      if (processor) {\n        // Returns either a value or a promise.\n        field = processor(newParams);\n      }\n\n      const processChildren = (childField) => {\n        if (\n          context.processChildren &&\n          childField !== null &&\n          typeof childField === 'object'\n        ) {\n          return mapValuesMayAsync(childField, (x, key) =>\n            this.processField({\n              field: x,\n              context: extendPath(context, key),\n              options,\n            })\n          );\n        } else {\n          return childField;\n        }\n      };\n\n      // Keep processing all child fields\n      if (field.then) {\n        // Wait for field to resolve\n        field = field.then((resolvedField) => {\n          return processChildren(resolvedField);\n        });\n      } else {\n        // Field is already resolved\n        field = processChildren(field);\n      }\n    } else {\n      // Keep processing all child fields\n      if (context.processChildren) {\n        if (Array.isArray(field)) {\n          field = promiseAllMayAsync(\n            (field as Array<any>).map((x, i) =>\n              this.processField({\n                field: x,\n                context: extendPath(context, i.toString()),\n                options,\n              })\n            )\n          );\n        }\n      }\n    }\n\n    return field;\n  }\n\n  private registerProcessor(name: string, processor: ProcessorCallback) {\n    if (this.processors[name]) {\n      throw new LrBadLogicException(\n        `Processor for field ${name} already exists.`\n      );\n    }\n    this.processors[name] = processor;\n  }\n\n  constructor(\n    private ngZone: NgZone,\n    private keyService: KeyService,\n    private common: CommonProcessorsService,\n    private tpprProcessor: TpPasswordResetProcessorService\n  ) {\n    this.registerProcessor(\n      'DirectoryNode',\n      common.series([\n        common.makeJsonParseProcessor({\n          plainFieldName: 'plainMeta',\n        }),\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'cipherMeta',\n        }),\n      ])\n    );\n    this.registerProcessor(\n      'FileStateNode',\n      common.series([\n        common.makeJsonParseProcessor({\n          plainFieldName: 'plainMeta',\n        }),\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'cipherMeta',\n        }),\n      ])\n    );\n    this.registerProcessor(\n      'ContactCardNode',\n      common.makeDecryptionProcessor({\n        cipherFieldName: 'cipherData',\n      })\n    );\n    this.registerProcessor(\n      'SharedContactCardNode',\n      common.series([\n        common.makeJsonParseProcessor({\n          plainFieldName: 'ownerPlainData',\n        }),\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'ownerCipherData',\n          getKeyId: ({ field }) => {\n            return field.ownerKey.id;\n          },\n        }),\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'receiverCipherData',\n          getKeyId: ({ field }) => {\n            return field.receiverKey.id;\n          },\n        }),\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'sharedCipherData',\n          getKeyId: ({ field }) => field.sharedKey.id,\n        }),\n      ])\n    );\n    this.registerProcessor(\n      'TpPasswordResetNode',\n      this.tpprProcessor.makeTpPasswordResetNodeProcessor()\n    );\n    this.registerProcessor(\n      'SharedTpClaimApproverNode',\n      common.series([\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'sharedCipherApprovalData',\n          getKeyId: ({ field }) => field.sharedKey.id,\n        }),\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'sharedCipherPartialAssemblyKey',\n          getKeyId: ({ field }) => field.sharedKey.id,\n        }),\n      ])\n    );\n    this.registerProcessor(\n      'TpAssemblyAsApproverNode',\n      common.series([\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'sharedCipherData',\n          getKeyId: ({ field }) => field.sharedKey.id,\n        }),\n      ])\n    );\n    this.registerProcessor(\n      'ScenarioNode',\n      common.series([\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'subjectCipherData',\n          getKeyId: ({ field }) => field.subjectKey.id,\n        }),\n      ])\n    );\n    this.registerProcessor(\n      'ScenarioReceiverNode',\n      common.series([\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'sharedCipherData',\n          getKeyId: ({ field }) => field.sharedKey.id,\n        }),\n      ])\n    );\n    this.registerProcessor(\n      'ScenarioReceiverDirectoryNode',\n      common.series([\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'sharedCipherData',\n          getKeyId: ({ field }) => field.sharedKey.id,\n        }),\n      ])\n    );\n    this.registerProcessor(\n      'ScenarioApproverAssemblyNode',\n      common.series([\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'assemblyCipherData',\n          getKeyId: ({ field }) => field.assemblyKey.id,\n        }),\n      ])\n    );\n    this.registerProcessor(\n      'ScenarioApproverSubAssemblyNode',\n      common.series([\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'subjectCipherData',\n          getKeyId: ({ field }) => field.subjectKey.id,\n        }),\n      ])\n    );\n    this.registerProcessor(\n      'ScenarioApproverNode',\n      common.series([\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'sharedCipherData',\n          getKeyId: ({ field }) => field.sharedKey.id,\n        }),\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'sharedCipherApprovalData',\n          getKeyId: ({ field }) => field.sharedKey.id,\n        }),\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'sharedCipherPartialAssemblyKey',\n          getKeyId: ({ field }) => field.sharedKey.id,\n        }),\n      ])\n    );\n    this.registerProcessor(\n      'ScenarioClaimantNode',\n      common.series([\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'sharedCipherData',\n          getKeyId: ({ field }) => field.sharedKey.id,\n        }),\n      ])\n    );\n    this.registerProcessor(\n      'TpAssemblyNode',\n      common.series([\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'subjectCipherData',\n          getKeyId: ({ field }) => field.subjectKey.id,\n        }),\n      ])\n    );\n    this.registerProcessor(\n      'TpSubAssemblyNode',\n      common.series([\n        common.makeDecryptionProcessor({\n          cipherFieldName: 'subjectCipherData',\n          getKeyId: ({ field }) => field.subjectKey.id,\n        }),\n      ])\n    );\n    this.registerProcessor(\n      'NotificationNode',\n      common.series([\n        common.makeJsonParseProcessor({\n          plainFieldName: 'plainMeta',\n        }),\n        common.makeJsonParseProcessor({\n          plainFieldName: 'plainData',\n        }),\n      ])\n    );\n  }\n}\n"]}
@@ -1,11 +1,11 @@
1
1
  import { __awaiter, __decorate } from "tslib";
2
2
  import { Injectable, NgZone } from '@angular/core';
3
- import { KeyGraphService } from '../../cryptography/key-graph.service';
3
+ import { KeyGraphService } from '../../key/key-graph.service';
4
+ import { LrBadRequestException } from '../../_common/exceptions';
4
5
  import { RunOutsideAngular } from '../../_common/run-outside-angular';
5
6
  import { processConnection, } from './common-processors.service';
6
- import { LrBadRequestException } from '../../_common/exceptions';
7
7
  import * as i0 from "@angular/core";
8
- import * as i1 from "../../cryptography/key-graph.service";
8
+ import * as i1 from "../../key/key-graph.service";
9
9
  let TpPasswordResetProcessorService = class TpPasswordResetProcessorService {
10
10
  constructor(ngZone, keyGraph) {
11
11
  this.ngZone = ngZone;
@@ -29,7 +29,8 @@ let TpPasswordResetProcessorService = class TpPasswordResetProcessorService {
29
29
  ret.receiverCipherClearJson = this.keyGraph.decryptFromString(pxk, approval.receiverCipher);
30
30
  }
31
31
  if (approval.receiverCipherPartialAssemblyKey) {
32
- ret.receiverCipherPartialAssemblyKeyClearJson = yield this.keyGraph.decryptFromString(pxk, approval.receiverCipherPartialAssemblyKey);
32
+ ret.receiverCipherPartialAssemblyKeyClearJson =
33
+ yield this.keyGraph.decryptFromString(pxk, approval.receiverCipherPartialAssemblyKey);
33
34
  }
34
35
  return ret;
35
36
  });
@@ -50,7 +51,7 @@ let TpPasswordResetProcessorService = class TpPasswordResetProcessorService {
50
51
  return __awaiter(this, void 0, void 0, function* () {
51
52
  // Subject key is encrypted user the master key. So if reset has been applied, then
52
53
  // these keys are not available any more.
53
- const { subjectKey, assemblyKey, assemblyCipherData, subAssemblies, } = assembly;
54
+ const { subjectKey, assemblyKey, assemblyCipherData, subAssemblies } = assembly;
54
55
  const ret = Object.assign(Object.assign({}, assembly), { subAssemblies: yield processConnection(subAssemblies, (node) => this.processTpSubAssemblyNode(node, subjectKey.id, applied)) });
55
56
  if (!applied) {
56
57
  if (assemblyCipherData) {
@@ -84,7 +85,7 @@ let TpPasswordResetProcessorService = class TpPasswordResetProcessorService {
84
85
  return ret;
85
86
  });
86
87
  }
87
- processTpAssemblyApproverNode(approver, applied) {
88
+ processTpAssemblyApproverNode(approver, _applied) {
88
89
  return __awaiter(this, void 0, void 0, function* () {
89
90
  return approver;
90
91
  });
@@ -106,4 +107,4 @@ TpPasswordResetProcessorService = __decorate([
106
107
  })
107
108
  ], TpPasswordResetProcessorService);
108
109
  export { TpPasswordResetProcessorService };
109
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tp-password-reset-processor.service.js","sourceRoot":"/opt/atlassian/pipelines/agent/build/projects/core/src/","sources":["lib/api/query-processor/tp-password-reset-processor.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, NgZone } from '@angular/core';\nimport { KeyGraphService } from '../../cryptography/key-graph.service';\nimport { RunOutsideAngular } from '../../_common/run-outside-angular';\nimport {\n  ID,\n  SharedTpAssemblyNode,\n  TpAssemblyApproverNode,\n  TpAssemblyNode,\n  TpSubAssemblyNode,\n} from '../types';\nimport {\n  processConnection,\n  ProcessorCallbackParams,\n} from './common-processors.service';\nimport {\n  TpPasswordResetUserNode,\n  TpPasswordResetUserApprovalNode,\n  TpPasswordResetNode,\n} from '../types';\nimport { Key } from '../../cryptography/cryptography.types';\nimport { LrBadRequestException } from '../../_common/exceptions';\n\n@RunOutsideAngular({\n  ngZoneName: 'ngZone',\n})\n@Injectable({\n  providedIn: 'root',\n})\nexport class TpPasswordResetProcessorService {\n  constructor(private ngZone: NgZone, private keyGraph: KeyGraphService) {}\n\n  async processTpPasswordResetUserNode(\n    node: TpPasswordResetUserNode\n  ): Promise<TpPasswordResetUserNode> {\n    const pxk = node.pxk?.id && (await this.keyGraph.getKey(node.pxk.id));\n\n    const ret = {\n      ...node,\n    };\n\n    if (pxk && node.approvals) {\n      ret.approvals = await Promise.all(\n        node.approvals.map((approval) =>\n          this.processTpPasswordResetUserApprovalNode(approval, pxk)\n        )\n      );\n    }\n\n    return ret;\n  }\n\n  private async processTpPasswordResetUserApprovalNode(\n    approval: TpPasswordResetUserApprovalNode,\n    pxk: Key\n  ) {\n    const ret = {\n      ...approval,\n    };\n\n    if (approval.receiverCipher) {\n      ret.receiverCipherClearJson = this.keyGraph.decryptFromString(\n        pxk,\n        approval.receiverCipher\n      );\n    }\n\n    if (approval.receiverCipherPartialAssemblyKey) {\n      ret.receiverCipherPartialAssemblyKeyClearJson = await this.keyGraph.decryptFromString(\n        pxk,\n        approval.receiverCipherPartialAssemblyKey\n      );\n    }\n    return ret;\n  }\n\n  makeTpPasswordResetNodeProcessor() {\n    return async ({\n      field,\n    }: ProcessorCallbackParams): Promise<TpPasswordResetNode> => {\n      const ret = {\n        ...field,\n      };\n\n      if (field.assembly) {\n        if (field.applied == null) {\n          throw new LrBadRequestException(\n            'If you request for field \"assembly\" in the TpPasswordResetNode, then you must also request the \"applied\" field'\n          );\n        }\n\n        ret.assembly = await this.processTpAssemblyNode(\n          field.assembly,\n          field.applied\n        );\n      }\n\n      return ret;\n    };\n  }\n\n  private async processTpAssemblyNode(\n    assembly: TpAssemblyNode,\n    applied: boolean\n  ): Promise<TpAssemblyNode> {\n    // Subject key is encrypted user the master key. So if reset has been applied, then\n    // these keys are not available any more.\n    const {\n      subjectKey,\n      assemblyKey,\n      assemblyCipherData,\n      subAssemblies,\n    } = assembly;\n\n    const ret: TpAssemblyNode = {\n      ...assembly,\n      subAssemblies: await processConnection(subAssemblies, (node) =>\n        this.processTpSubAssemblyNode(node, subjectKey.id, applied)\n      ),\n    };\n\n    if (!applied) {\n      if (assemblyCipherData) {\n        ret.assemblyCipherDataClearJson = await this.keyGraph.decryptFromString(\n          assemblyKey.id,\n          assemblyCipherData\n        );\n      }\n    }\n\n    return ret;\n  }\n\n  private async processTpSubAssemblyNode(\n    subAssembly: TpSubAssemblyNode,\n    subjectKeyId: ID,\n    applied: boolean\n  ): Promise<TpSubAssemblyNode> {\n    const { subjectCipherData, approvers } = subAssembly;\n\n    // const ret: TpSubAssemblyNode = {\n    //   ...subAssembly,\n    //   approvers: {\n    //     ...approvers,\n    //     edges: await Promise.all(\n    //       approvers.edges.map(async (edge) => ({\n    //         ...edge,\n    //         node: await this.processTpAssemblyApproverNode(edge.node, applied),\n    //       }))\n    //     ),\n    //   },\n    // };\n    const ret: TpSubAssemblyNode = {\n      ...subAssembly,\n      approvers: await processConnection(approvers, (node) =>\n        this.processTpAssemblyApproverNode(node, applied)\n      ),\n    };\n\n    if (!applied) {\n      if (subjectCipherData) {\n        ret.subjectCipherDataClearJson = await this.keyGraph.decryptFromString(\n          subjectKeyId,\n          subjectCipherData\n        );\n      }\n    }\n\n    return ret;\n  }\n\n  private async processTpAssemblyApproverNode(\n    approver: TpAssemblyApproverNode,\n    applied: boolean\n  ) {\n    return approver;\n  }\n}\n"]}
110
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tp-password-reset-processor.service.js","sourceRoot":"","sources":["../../../../../../../projects/core/src/lib/api/query-processor/tp-password-reset-processor.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, NgZone } from '@angular/core';\nimport { KeyGraphService } from '../../key/key-graph.service';\nimport { Key } from '../../key/key.types';\nimport { LrBadRequestException } from '../../_common/exceptions';\nimport { RunOutsideAngular } from '../../_common/run-outside-angular';\nimport {\n  ID,\n  TpAssemblyApproverNode,\n  TpAssemblyNode,\n  TpPasswordResetNode,\n  TpPasswordResetUserApprovalNode,\n  TpPasswordResetUserNode,\n  TpSubAssemblyNode,\n} from '../types';\nimport {\n  processConnection,\n  ProcessorCallbackParams,\n} from './common-processors.service';\n\n@RunOutsideAngular({\n  ngZoneName: 'ngZone',\n})\n@Injectable({\n  providedIn: 'root',\n})\nexport class TpPasswordResetProcessorService {\n  constructor(private ngZone: NgZone, private keyGraph: KeyGraphService) {}\n\n  async processTpPasswordResetUserNode(\n    node: TpPasswordResetUserNode\n  ): Promise<TpPasswordResetUserNode> {\n    const pxk = node.pxk?.id && (await this.keyGraph.getKey(node.pxk.id));\n\n    const ret = {\n      ...node,\n    };\n\n    if (pxk && node.approvals) {\n      ret.approvals = await Promise.all(\n        node.approvals.map((approval) =>\n          this.processTpPasswordResetUserApprovalNode(approval, pxk)\n        )\n      );\n    }\n\n    return ret;\n  }\n\n  private async processTpPasswordResetUserApprovalNode(\n    approval: TpPasswordResetUserApprovalNode,\n    pxk: Key\n  ) {\n    const ret = {\n      ...approval,\n    };\n\n    if (approval.receiverCipher) {\n      ret.receiverCipherClearJson = this.keyGraph.decryptFromString(\n        pxk,\n        approval.receiverCipher\n      );\n    }\n\n    if (approval.receiverCipherPartialAssemblyKey) {\n      ret.receiverCipherPartialAssemblyKeyClearJson =\n        await this.keyGraph.decryptFromString(\n          pxk,\n          approval.receiverCipherPartialAssemblyKey\n        );\n    }\n    return ret;\n  }\n\n  makeTpPasswordResetNodeProcessor() {\n    return async ({\n      field,\n    }: ProcessorCallbackParams): Promise<TpPasswordResetNode> => {\n      const ret = {\n        ...field,\n      };\n\n      if (field.assembly) {\n        if (field.applied == null) {\n          throw new LrBadRequestException(\n            'If you request for field \"assembly\" in the TpPasswordResetNode, then you must also request the \"applied\" field'\n          );\n        }\n\n        ret.assembly = await this.processTpAssemblyNode(\n          field.assembly,\n          field.applied\n        );\n      }\n\n      return ret;\n    };\n  }\n\n  private async processTpAssemblyNode(\n    assembly: TpAssemblyNode,\n    applied: boolean\n  ): Promise<TpAssemblyNode> {\n    // Subject key is encrypted user the master key. So if reset has been applied, then\n    // these keys are not available any more.\n    const { subjectKey, assemblyKey, assemblyCipherData, subAssemblies } =\n      assembly;\n\n    const ret: TpAssemblyNode = {\n      ...assembly,\n      subAssemblies: await processConnection(subAssemblies, (node) =>\n        this.processTpSubAssemblyNode(node, subjectKey.id, applied)\n      ),\n    };\n\n    if (!applied) {\n      if (assemblyCipherData) {\n        ret.assemblyCipherDataClearJson = await this.keyGraph.decryptFromString(\n          assemblyKey.id,\n          assemblyCipherData\n        );\n      }\n    }\n\n    return ret;\n  }\n\n  private async processTpSubAssemblyNode(\n    subAssembly: TpSubAssemblyNode,\n    subjectKeyId: ID,\n    applied: boolean\n  ): Promise<TpSubAssemblyNode> {\n    const { subjectCipherData, approvers } = subAssembly;\n\n    // const ret: TpSubAssemblyNode = {\n    //   ...subAssembly,\n    //   approvers: {\n    //     ...approvers,\n    //     edges: await Promise.all(\n    //       approvers.edges.map(async (edge) => ({\n    //         ...edge,\n    //         node: await this.processTpAssemblyApproverNode(edge.node, applied),\n    //       }))\n    //     ),\n    //   },\n    // };\n    const ret: TpSubAssemblyNode = {\n      ...subAssembly,\n      approvers: await processConnection(approvers, (node) =>\n        this.processTpAssemblyApproverNode(node, applied)\n      ),\n    };\n\n    if (!applied) {\n      if (subjectCipherData) {\n        ret.subjectCipherDataClearJson = await this.keyGraph.decryptFromString(\n          subjectKeyId,\n          subjectCipherData\n        );\n      }\n    }\n\n    return ret;\n  }\n\n  private async processTpAssemblyApproverNode(\n    approver: TpAssemblyApproverNode,\n    _applied: boolean\n  ) {\n    return approver;\n  }\n}\n"]}
@@ -4,4 +4,5 @@
4
4
  // These types map directory to types of the same name in graphql.
5
5
  // We use these aliases in case in the future we wish to reify the types and do
6
6
  // additional automated conversion.
7
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JhcGhxbC50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIvb3B0L2F0bGFzc2lhbi9waXBlbGluZXMvYWdlbnQvYnVpbGQvcHJvamVjdHMvY29yZS9zcmMvIiwic291cmNlcyI6WyJsaWIvYXBpL3R5cGVzL2dyYXBocWwudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEseURBQXlEO0FBQ3pELGNBQWM7QUFDZCx5REFBeUQ7QUFDekQsa0VBQWtFO0FBQ2xFLCtFQUErRTtBQUMvRSxtQ0FBbUMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS1cbi8vIEJhc2ljIHR5cGVzXG4vLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS1cbi8vIFRoZXNlIHR5cGVzIG1hcCBkaXJlY3RvcnkgdG8gdHlwZXMgb2YgdGhlIHNhbWUgbmFtZSBpbiBncmFwaHFsLlxuLy8gV2UgdXNlIHRoZXNlIGFsaWFzZXMgaW4gY2FzZSBpbiB0aGUgZnV0dXJlIHdlIHdpc2ggdG8gcmVpZnkgdGhlIHR5cGVzIGFuZCBkb1xuLy8gYWRkaXRpb25hbCBhdXRvbWF0ZWQgY29udmVyc2lvbi5cblxuZXhwb3J0IHR5cGUgSUQgPSBzdHJpbmc7XG4vLyBTZXJ2ZXIgcmVxdWlyZXMgdGhpcyB0byBoYXZlIGNlcnRhaW4gZm9ybWF0LiBCdXQgY2xpZW50XG4vLyBqdXN0IHRyZWF0cyB0aGlzIGFzIGFuIG9wYXF1ZSBzdHJpbmcuXG5leHBvcnQgdHlwZSBMclJlbGF5SWRJbnB1dCA9IHN0cmluZztcbmV4cG9ydCB0eXBlIERhdGVUaW1lID0gc3RyaW5nO1xuLy8gVGhpcyBpcyBiYXNpY2FsbHkgdGhlIHJlc3VsdHMgb2Y6IEpTT04uc3RyaW5naWZ5KG9iailcbi8vIFNlcnZlciB2YWxpZGF0ZWQgdG8gbWFrZSBzdXJlIGl0IGNhbiBKU09OLnBhcnNlKCkgdGhpcy5cbmV4cG9ydCB0eXBlIExySlNPTlN0cmluZyA9IHN0cmluZztcbi8vIEpTT05TdHJpbmcgaXMgYSB0eXBlIGZyb20gZ3JhcGhlbmUuIERCIEpTT04gZmllbGRzIG1hcHMgdG8gdGhpcyB0eXBlXG4vLyBhdXRvbWF0aWNhbGx5LlxuLy8gV2hlcmUgYXMgTHJKU09OU3RyaW5nIGlzIG91dCBjdXN0b20gaW1wbGVtZW50YXRpb24gZm9yIGlucHV0IHZhcmlhYmxlcy5cbmV4cG9ydCB0eXBlIEpTT05TdHJpbmcgPSBzdHJpbmc7XG4vLyBUaGlzIGF2b2lkIHRyaWdnZXJpbmcgbGludGluZyBydWxlIHRoYXQgcHJvaGliaXRzIHVzaW5nIHR5cGUgYW55LlxuZXhwb3J0IHR5cGUgSlNPTk9iamVjdCA9IGFueTtcbmV4cG9ydCB0eXBlIExyRW1haWwgPSBzdHJpbmc7XG5leHBvcnQgdHlwZSBHZW5lcmljU2NhbGFyID0gYW55O1xuZXhwb3J0IHR5cGUgVVVJRCA9IHN0cmluZztcblxuZXhwb3J0IGludGVyZmFjZSBOb2RlIHtcbiAgaWQ/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVGltZVN0YW1wZWQge1xuICBjcmVhdGVkPzogRGF0ZVRpbWU7XG4gIG1vZGlmaWVkPzogRGF0ZVRpbWU7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRWRnZTxOb2RlVHlwZSBleHRlbmRzIE5vZGU+IHtcbiAgbm9kZT86IE5vZGVUeXBlO1xuICBjdXJzb3I/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29ubmVjdGlvbjxOb2RlVHlwZT4ge1xuICBwYWdlSW5mbz86IFBhZ2VJbmZvO1xuICBlZGdlcz86IEVkZ2U8Tm9kZVR5cGU+W107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGFnZUluZm8ge1xuICBoYXNOZXh0UGFnZT86IGJvb2xlYW47XG4gIGhhc1ByZXZpb3VzUGFnZT86IGJvb2xlYW47XG4gIHN0YXJ0Q3Vyc29yPzogc3RyaW5nO1xuICBlbmRDdXJzb3I/OiBzdHJpbmc7XG59XG4iXX0=
7
+ export {};
8
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JhcGhxbC50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvc3JjL2xpYi9hcGkvdHlwZXMvZ3JhcGhxbC50eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSx5REFBeUQ7QUFDekQsY0FBYztBQUNkLHlEQUF5RDtBQUN6RCxrRUFBa0U7QUFDbEUsK0VBQStFO0FBQy9FLG1DQUFtQyIsInNvdXJjZXNDb250ZW50IjpbIi8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLVxuLy8gQmFzaWMgdHlwZXNcbi8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLVxuLy8gVGhlc2UgdHlwZXMgbWFwIGRpcmVjdG9yeSB0byB0eXBlcyBvZiB0aGUgc2FtZSBuYW1lIGluIGdyYXBocWwuXG4vLyBXZSB1c2UgdGhlc2UgYWxpYXNlcyBpbiBjYXNlIGluIHRoZSBmdXR1cmUgd2Ugd2lzaCB0byByZWlmeSB0aGUgdHlwZXMgYW5kIGRvXG4vLyBhZGRpdGlvbmFsIGF1dG9tYXRlZCBjb252ZXJzaW9uLlxuXG5leHBvcnQgdHlwZSBJRCA9IHN0cmluZztcbi8vIFNlcnZlciByZXF1aXJlcyB0aGlzIHRvIGhhdmUgY2VydGFpbiBmb3JtYXQuIEJ1dCBjbGllbnRcbi8vIGp1c3QgdHJlYXRzIHRoaXMgYXMgYW4gb3BhcXVlIHN0cmluZy5cbmV4cG9ydCB0eXBlIExyUmVsYXlJZElucHV0ID0gc3RyaW5nO1xuZXhwb3J0IHR5cGUgRGF0ZVRpbWUgPSBzdHJpbmc7XG4vLyBUaGlzIGlzIGJhc2ljYWxseSB0aGUgcmVzdWx0cyBvZjogSlNPTi5zdHJpbmdpZnkob2JqKVxuLy8gU2VydmVyIHZhbGlkYXRlZCB0byBtYWtlIHN1cmUgaXQgY2FuIEpTT04ucGFyc2UoKSB0aGlzLlxuZXhwb3J0IHR5cGUgTHJKU09OU3RyaW5nID0gc3RyaW5nO1xuLy8gSlNPTlN0cmluZyBpcyBhIHR5cGUgZnJvbSBncmFwaGVuZS4gREIgSlNPTiBmaWVsZHMgbWFwcyB0byB0aGlzIHR5cGVcbi8vIGF1dG9tYXRpY2FsbHkuXG4vLyBXaGVyZSBhcyBMckpTT05TdHJpbmcgaXMgb3V0IGN1c3RvbSBpbXBsZW1lbnRhdGlvbiBmb3IgaW5wdXQgdmFyaWFibGVzLlxuZXhwb3J0IHR5cGUgSlNPTlN0cmluZyA9IHN0cmluZztcbi8vIFRoaXMgYXZvaWQgdHJpZ2dlcmluZyBsaW50aW5nIHJ1bGUgdGhhdCBwcm9oaWJpdHMgdXNpbmcgdHlwZSBhbnkuXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWV4cGxpY2l0LWFueVxuZXhwb3J0IHR5cGUgSlNPTk9iamVjdCA9IGFueTtcbmV4cG9ydCB0eXBlIExyRW1haWwgPSBzdHJpbmc7XG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWV4cGxpY2l0LWFueVxuZXhwb3J0IHR5cGUgR2VuZXJpY1NjYWxhciA9IGFueTtcbmV4cG9ydCB0eXBlIFVVSUQgPSBzdHJpbmc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgTm9kZSB7XG4gIGlkPzogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFRpbWVTdGFtcGVkIHtcbiAgY3JlYXRlZD86IERhdGVUaW1lO1xuICBtb2RpZmllZD86IERhdGVUaW1lO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEVkZ2U8Tm9kZVR5cGUgZXh0ZW5kcyBOb2RlPiB7XG4gIG5vZGU/OiBOb2RlVHlwZTtcbiAgY3Vyc29yPzogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIENvbm5lY3Rpb248Tm9kZVR5cGU+IHtcbiAgcGFnZUluZm8/OiBQYWdlSW5mbztcbiAgZWRnZXM/OiBFZGdlPE5vZGVUeXBlPltdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFBhZ2VJbmZvIHtcbiAgaGFzTmV4dFBhZ2U/OiBib29sZWFuO1xuICBoYXNQcmV2aW91c1BhZ2U/OiBib29sZWFuO1xuICBzdGFydEN1cnNvcj86IHN0cmluZztcbiAgZW5kQ3Vyc29yPzogc3RyaW5nO1xufVxuIl19
@@ -1,3 +1,3 @@
1
1
  export * from './graphql.types';
2
2
  export * from './lr-graphql.types';
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiL29wdC9hdGxhc3NpYW4vcGlwZWxpbmVzL2FnZW50L2J1aWxkL3Byb2plY3RzL2NvcmUvc3JjLyIsInNvdXJjZXMiOlsibGliL2FwaS90eXBlcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGlCQUFpQixDQUFDO0FBQ2hDLGNBQWMsb0JBQW9CLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2dyYXBocWwudHlwZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9sci1ncmFwaHFsLnR5cGVzJztcbiJdfQ==
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3NyYy9saWIvYXBpL3R5cGVzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyxvQkFBb0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZ3JhcGhxbC50eXBlcyc7XG5leHBvcnQgKiBmcm9tICcuL2xyLWdyYXBocWwudHlwZXMnO1xuIl19
@@ -116,4 +116,4 @@ export var LinkTypeField;
116
116
  LinkTypeField["HARD"] = "HARD";
117
117
  LinkTypeField["SOFT"] = "SOFT";
118
118
  })(LinkTypeField || (LinkTypeField = {}));
119
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lr-graphql.types.js","sourceRoot":"/opt/atlassian/pipelines/agent/build/projects/core/src/","sources":["lib/api/types/lr-graphql.types.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Connection,\n  DateTime,\n  GenericScalar,\n  ID,\n  JSONObject,\n  JSONString,\n  LrEmail,\n  Node,\n  TimeStamped,\n} from './graphql.types';\n\nexport function mapEdges<T>(connection: Connection<T>) {\n  return connection.edges.map((edge) => edge.node);\n}\n\nexport interface FeaturesNode {\n  myVault: string[];\n  tpVault: string[];\n  shareVault: string[];\n}\n\nexport enum UserDeleteState {\n  REQUESTED = 'REQUESTED',\n}\n\nexport interface UserDeleteNode extends Node, TimeStamped {\n  state?: UserDeleteState;\n}\n\nexport enum PlanState {\n  ENABLED = 'ENABLED',\n  DISABLED = 'DISABLED',\n}\n\nexport interface PlanNode extends Node {\n  name?: string;\n  data?: JSONString;\n  state?: PlanState;\n}\n\nexport interface UserPlanStripeNode extends Node, TimeStamped {\n  subscriptionId?: string;\n  priceId?: string;\n}\n\nexport interface UserPlanNode extends Node, TimeStamped {\n  user?: UserNode;\n  plan?: PlanNode;\n  periodEnd?: DateTime;\n  stripe?: UserPlanStripeNode;\n  issuer?: UserNode;\n}\n\nexport interface UserStripeNode extends Node, TimeStamped {\n  customer?: GenericScalar;\n}\n\nexport interface PassKeyNode extends Node, TimeStamped {\n  passKeyParams?: GenericScalar;\n  passIdpParams?: GenericScalar;\n  wrappedPassIdpVerifierPrk?: GenericScalar;\n}\n\nexport interface CurrentUserKeyNode extends Node, TimeStamped {\n  passKeys?: PassKeyNode[];\n  passKey?: PassKeyNode;\n  rootKey?: KeyNode;\n  masterKey?: KeyNode;\n  pxk?: KeyNode;\n  sigPxk?: KeyNode;\n}\n\n// ------------------------------------------------------\n// Node types\n// ------------------------------------------------------\nexport interface UserNode extends Node {\n  username?: string;\n  contactCards?: Connection<ContactCardNode>;\n  currentUserKey?: CurrentUserKeyNode;\n  ownedContactCard?: SharedContactCardNode;\n  receivedContactCard?: SharedContactCardNode;\n  isCurrentUser?: boolean;\n  haveTp?: boolean;\n  stripe?: UserStripeNode;\n  userPlans?: Connection<UserPlanNode>;\n  userDelete?: UserDeleteNode;\n  features?: FeaturesNode;\n  userFeatureState?: UserFeatureState;\n}\n\nexport interface UserFeatureState extends TimeStamped {\n  notificationsLastViewed?: DateTime;\n}\n\nexport interface ServerTime {\n  timestamp?: string;\n}\n\nexport interface KeyNode extends Node, TimeStamped {\n  pbk?: string;\n}\n\nexport interface ContactCardNode extends Node, TimeStamped {\n  owner?: UserNode;\n  publicDataSig?: string;\n  publicSearchableSig?: string;\n  sigPxk?: KeyNode;\n  defaultFrom?: DateTime;\n  publicData?: string;\n  publicSearchable?: string;\n  cipherData?: string;\n  cipherDataClearJson?: JSONObject;\n  key?: KeyNode;\n  plainData?: string;\n  plainDataSig?: string;\n}\n\nexport interface DirectoryNode extends Node, TimeStamped {\n  plainMeta?: JSONString;\n  plainMetaJson?: JSONObject;\n  cipherMeta?: string;\n  cipherMetaClearJson?: JSONObject;\n  archived?: boolean;\n  keyId?: ID;\n  childFileLinks?: Connection<FileLinkNode>;\n  childDirectoryLinks?: Connection<DirectoryLinkNode>;\n  parentDirectoryLinks?: Connection<DirectoryLinkNode>;\n  nParentDirectoryLinks?: DirectoryLinkNodeLrNList;\n  nChildDirectoryLinks?: DirectoryLinkNodeLrNList;\n  nChildFileLinks?: FileLinkNodeLrNList;\n  descendants?: Descendants;\n  accessRoles?: AccessRole[];\n}\n\nexport interface FileNode extends Node, TimeStamped {\n  currentVersion?: FileVersionNode;\n  archived?: boolean;\n  versions?: Connection<FileVersionNode>;\n  keyId?: ID;\n  parentDirectoryLinks?: Connection<FileLinkNode>;\n  nParentDirectoryLinks?: FileLinkNodeLrNList;\n  accessRoles?: AccessRole[];\n}\n\nexport interface DirectoryLinkNode extends Node, TimeStamped {\n  parentDirectory?: DirectoryNode;\n  childDirectory?: DirectoryNode;\n  linkType?: LinkTypeField;\n}\n\nexport interface FileLinkNode extends Node, TimeStamped {\n  parentDirectory?: DirectoryNode;\n  childFile?: FileNode;\n  linkType?: LinkTypeField;\n}\n\nexport interface DirectoryLinkNodeLrNList {\n  list?: DirectoryLinkNode[];\n}\n\nexport interface FileLinkNodeLrNList {\n  list?: FileLinkNode[];\n}\n\nexport interface Descendants {\n  directories?: Connection<DirectoryNode>;\n  files?: Connection<FileNode>;\n  directoriesCount?: number;\n  filesCount?: number;\n}\n\nexport enum AccessRoleChoice {\n  READER = 'READER',\n  WRITER = 'WRITER',\n  ADMIN = 'ADMIN',\n  DENY = 'DENY',\n  OWNER = 'OWNER',\n}\n\nexport enum AccessRoleMethod {\n  inherited = 'inherited',\n  direct = 'direct',\n}\n\nexport interface AccessRole {\n  issuer?: UserNode;\n  subject?: UserNode;\n  role?: AccessRoleChoice;\n  method?: AccessRoleMethod;\n  inheritedFrom?: DirectoryNode;\n  trustedParty?: TpNode;\n  isIssuer?: boolean;\n}\n\nexport enum FileOperationField {\n  CREATE = 'CREATE',\n  READ = 'READ',\n  UPDATE = 'UPDATE',\n  REVERT = 'REVERT',\n  DELETE = 'DELETE',\n}\n\nexport interface FileVersionNode extends Node, TimeStamped {\n  file?: FileNode;\n  state?: FileStateNode;\n  operation?: FileOperationField;\n  author?: UserNode;\n}\nexport interface FileStateNode extends Node, TimeStamped {\n  plainMeta?: JSONString;\n  plainMetaJson?: JSONObject;\n  cipherMeta?: string;\n  cipherMetaClearJson?: JSONObject;\n  contentResource?: string;\n  versions?: Connection<FileVersionNode>;\n  keyId: ID;\n}\n\nexport enum KeyExchangeOtkState {\n  OTK_INITIATED = 'OTK_INITIATED',\n  OTK_ACCEPTED = 'OTK_ACCEPTED',\n  OTK_COMPLETED = 'OTK_COMPLETED',\n}\n\nexport interface ContactCardSharedCipherData {\n  // Shared read access between initiator and responder. But only the initiator has write access.\n  sharedCipherDataClearJson: JSONObject;\n}\n\n/**\n * The contents of the one-time key cipher\n */\nexport interface OtKeyCipherClearJson2 {\n  // Used to confirm to the initiator that the responder has access to the one-time key.\n  nonce: string;\n  // Data sent from initiator to the responder\n  initiator: {\n    oneTimePbk: object; // one-time public encryption key the responder will use to send data back to the initiator\n    pbk: object; // public encryption key\n    sigPbk: object; // public signing key\n    message?: JSONObject;\n    contactCard?: ContactCardSharedCipherData;\n  };\n}\n\nexport interface KeyExchangeOtkNode extends Node, TimeStamped {\n  state?: KeyExchangeOtkState;\n  sharedKey?: KeyNode;\n  mkSharedKey?: KeyNode;\n  initiatorSigPxk?: KeyNode;\n  responderSigPxk?: KeyNode;\n  initiatorOneTimePbkCipher?: string;\n  otKeyParams?: string;\n  otKeyCipher?: string;\n  otKeyCipherClearJson?: OtKeyCipherClearJson2;\n  responderPbkCipher?: string;\n}\n\nexport enum KeyExchangeState {\n  IN_PROGRESS = 'IN_PROGRESS',\n  COMPLETED = 'COMPLETED',\n  DECLINED = 'DECLINED',\n  CANCELLED = 'CANCELLED',\n  DELETED = 'DELETED',\n}\n\nexport enum KeyExchangeMode {\n  OTK = 'OTK',\n}\n\nexport interface KeyExchangeNode extends Node, TimeStamped {\n  expiryTime?: DateTime;\n  token?: string;\n  tokenExpiryTime?: DateTime;\n  state?: KeyExchangeState;\n  mode?: KeyExchangeMode;\n  initiator?: UserNode;\n  responder?: UserNode;\n  initiatorRootKeyCipher?: string;\n  responderRootKeyCipher?: string;\n  initiatorActionRequired?: boolean;\n  responderActionRequired?: boolean;\n  createTp?: boolean;\n  otk?: KeyExchangeOtkNode;\n  isInitiator?: boolean;\n  isExpired?: boolean;\n  responderEmailAddress?: LrEmail;\n}\n\nexport interface SharedItems {\n  directories?: Connection<DirectoryNode>;\n  files?: Connection<FileNode>;\n}\n\nexport interface SharedContactCardNode extends Node, TimeStamped {\n  owner?: UserNode;\n  receiver?: UserNode;\n  sharedKey?: KeyNode;\n  sharedCipherData?: string;\n  sharedCipherDataClearJson?: JSONObject;\n  sharedCipherDataSig?: string;\n  sharedCipherDataSigPxk?: KeyNode;\n  ownerCipherData?: string;\n  ownerCipherDataClearJson?: JSONObject;\n  ownerKey?: KeyNode;\n  ownerPlainData?: string;\n  ownerPlainDataJson?: JSONObject;\n  ownerPlainDataSig?: string;\n  receiverCipherData?: string;\n  receiverCipherDataClearJson?: JSONObject;\n  receiverKey?: KeyNode;\n}\n\nexport interface UserSharedKeyNode extends Node, TimeStamped {\n  keyExchange?: KeyExchangeNode;\n  user?: UserNode;\n  userPrk?: KeyNode;\n  userSigPrk?: KeyNode;\n  other?: UserNode;\n  otherPbk?: KeyNode;\n  otherSigPbk?: KeyNode;\n  sharedKey?: KeyNode;\n  mkSharedKey?: KeyNode;\n  mkPxk?: KeyNode;\n  mkReshareRequestCipher?: string;\n  mkReshareResponseCipher?: string;\n  mkReshareRequestCipherClearJson?: JSONObject;\n  mkReshareResponseCipherClearJson?: JSONObject;\n  mkReshareRequestSent?: boolean;\n  mkReshareResponseSent?: boolean;\n}\n\nexport interface CurrentUserSharedKeyNode extends Node, TimeStamped {\n  user?: UserNode;\n  other?: UserNode;\n  userSharedKey?: UserSharedKeyNode;\n}\n\nexport interface TpNode extends Node, TimeStamped {\n  user?: UserNode;\n  other?: UserNode;\n  currentUserSharedKey?: CurrentUserSharedKeyNode;\n  isCompleted?: boolean;\n  sharedKey?: KeyNode;\n  sharedContactCard?: SharedContactCardNode;\n  myContactCard?: SharedContactCardNode;\n  myItems?: SharedItems;\n  sharedItems?: SharedItems;\n  myScenarios?: Connection<ScenarioNode>;\n  sharedScenarios?: Connection<SharedScenarioNode>;\n}\n\nexport enum TpAssemblyState {\n  DISABLED = 'DISABLED',\n  ENABLED = 'ENABLED',\n  CLAIMED = 'CLAIMED',\n  APPROVED = 'APPROVED',\n  REJECTED = 'REJECTED',\n  EXPIRED = 'EXPIRED',\n  CANCELLED = 'CANCELLED',\n  RESET = 'RESET',\n}\n\nexport enum TpClaimState {\n  CLAIMED = 'CLAIMED',\n  APPROVED = 'APPROVED',\n  REJECTED = 'REJECTED',\n  EXPIRED = 'EXPIRED',\n  CANCELLED = 'CANCELLED',\n  RESET = 'RESET',\n}\n\nexport enum TpClaimApproverState {\n  CLAIMED = 'CLAIMED',\n  APPROVED = 'APPROVED',\n  REJECTED = 'REJECTED',\n}\n\nexport interface TpPasswordResetApproval extends Node, TimeStamped {\n  approverEmail?: string;\n  receiverCipher?: string;\n  receiverCipherClearJson?: JSONObject;\n  receiverCipherPartialAssemblyKey?: string;\n  receiverCipherPartialAssemblyKeyClearJson?: JSONObject;\n}\n\nexport interface TpPasswordResetUserApprovalNode extends Node, TimeStamped {\n  receiverCipher?: string;\n  receiverCipherClearJson?: JSONObject;\n  receiverCipherPartialAssemblyKey?: string;\n  receiverCipherPartialAssemblyKeyClearJson?: JSONObject;\n  approverEmail?: string;\n}\n\nexport interface TpPasswordResetUserApprover {\n  name?: string;\n  email?: string;\n  state?: TpClaimApproverState;\n}\n\nexport interface TpPasswordResetUserSubAssembly {\n  singleReject?: boolean;\n  quorum?: number;\n  approvers?: TpPasswordResetUserApprover[];\n}\n\nexport interface TpPasswordResetUserAssembly {\n  singleReject?: boolean;\n  quorum?: number;\n  subAssemblies?: TpPasswordResetUserSubAssembly[];\n}\n\nexport interface TpPasswordResetUserNode {\n  username?: string;\n  resetUsername?: string;\n  state?: TpClaimState;\n  passKey?: PassKeyNode;\n  masterKey?: KeyNode;\n  pxk?: KeyNode;\n  sessionEncryptionKey?: string;\n  approvals?: TpPasswordResetUserApprovalNode[];\n  assemblyCipherData?: string;\n  wrappedAssemblyKeyVerifierPrk?: string;\n  assembly?: TpPasswordResetUserAssembly;\n}\n\nexport interface TpPasswordResetNode extends Node, TimeStamped {\n  assembly?: TpAssemblyNode;\n  request?: TpPasswordResetRequestNode;\n  applied?: boolean;\n}\n\nexport interface TpPasswordResetRequestNode extends Node, TimeStamped {\n  state?: TpClaimState;\n}\n\nexport interface TpAssemblyNode extends Node, TimeStamped {\n  id?: ID;\n  singleReject?: boolean;\n  quorum?: number;\n  subjectKey?: KeyNode;\n  subjectCipherData?: string;\n  subjectCipherDataClearJson?: JSONObject;\n  assemblyKey?: KeyNode;\n  assemblyCipherData?: string;\n  assemblyCipherDataClearJson?: JSONObject;\n  subAssemblies?: Connection<TpSubAssemblyNode>;\n}\n\nexport interface TpSubAssemblyNode extends Node, TimeStamped {\n  singleReject?: boolean;\n  quorum?: number;\n  subjectCipherData?: string;\n  subjectCipherDataClearJson?: string;\n  approvers?: Connection<TpAssemblyApproverNode>;\n}\n\nexport interface TpAssemblyApproverNode extends Node, TimeStamped {\n  sharedKey?: KeyNode;\n  sharedCipherData?: string;\n  sharedCipherDataClearJson?: JSONObject;\n  sharedCipherApprovalData?: string;\n  sharedCipherApprovalDataClearJson?: JSONObject;\n  tp?: TpNode;\n}\n\nexport interface SharedTpPasswordResetNode extends Node, TimeStamped {\n  assembly?: SharedTpAssemblyNode;\n  tp?: TpNode;\n  sharedRequest?: SharedTpPasswordResetRequestNode;\n}\n\nexport interface SharedTpAssemblyNode extends Node, TimeStamped {\n  asApprovers?: Connection<TpAssemblyAsApproverNode>;\n}\n\nexport interface TpAssemblyAsApproverNode extends Node, TimeStamped {\n  sharedKey?: KeyNode;\n  sharedCipherData?: string;\n}\n\nexport interface SharedTpPasswordResetRequestNode extends Node, TimeStamped {\n  claim?: SharedTpClaimNode;\n  pxk?: KeyNode;\n}\n\nexport interface SharedTpClaimNode extends Node, TimeStamped {\n  state?: TpClaimState;\n  asClaimApprovers?: Connection<SharedTpClaimApproverNode>;\n}\n\nexport interface SharedTpClaimApproverNode extends Node, TimeStamped {\n  state?: TpClaimApproverState;\n  sharedKey?: KeyNode;\n  sharedCipherApprovalData?: string;\n  sharedCipherApprovalDataClearJson?: JSONObject;\n  sharedCipherPartialAssemblyKey?: string;\n  sharedCipherPartialAssemblyKeyClearJson?: JSONObject;\n  receiverApprovals?: Connection<SharedTpClaimReceiverApprovalNode>;\n}\n\nexport interface SharedTpClaimReceiverApprovalNode extends Node, TimeStamped {\n  pxk?: KeyNode;\n}\n\nexport enum LockState {\n  UNLOCKED = 'UNLOCKED',\n  MUTEX_LOCKED = 'MUTEX_LOCKED',\n}\n\nexport enum ScenarioState {\n  DISABLED = 'DISABLED',\n  ENABLED = 'ENABLED',\n  CLAIMED = 'CLAIMED',\n  APPROVED = 'APPROVED',\n}\n\nexport enum ClaimState {\n  CLAIMED = 'CLAIMED',\n  EXPIRED = 'EXPIRED',\n  APPROVED = 'APPROVED',\n  REJECTED = 'REJECTED',\n  CANCELLED = 'CANCELLED',\n  RESET = 'RESET',\n}\n\nexport enum ClaimApproverState {\n  CLAIMED = 'CLAIMED',\n  APPROVED = 'APPROVED',\n  REJECTED = 'REJECTED',\n}\n\nexport enum ScenarioLastClaimState {\n  CLAIMED = 'CLAIMED',\n  APPROVED = 'APPROVED',\n  REJECTED = 'REJECTED',\n  EXPIRED = 'EXPIRED',\n  CANCELLED = 'CANCELLED',\n  RESET = 'RESET',\n}\n\nexport interface ScenarioLatestClaim {\n  state?: ScenarioLastClaimState;\n  created?: DateTime;\n}\n\nexport interface ScenarioNode extends Node, TimeStamped {\n  subject?: UserNode;\n  subjectKey?: KeyNode;\n  subjectCipherData?: string;\n  subjectCipherDataClearJson?: JSONObject;\n  assembly?: TpAssemblyNode;\n  state?: ScenarioState;\n  claimants?: Connection<ScenarioClaimantNode>;\n  receivers?: Connection<ScenarioReceiverNode>;\n  claims?: Connection<ScenarioClaimNode>;\n  claim?: ScenarioClaimNode;\n  assemblyState?: ScenarioAssemblyState;\n  latestClaim?: ScenarioLatestClaim;\n}\n\nexport interface ScenarioClaimNode extends Node, TimeStamped {\n  claimant?: ScenarioClaimantNode;\n  state?: ClaimState;\n  scenario?: ScenarioNode;\n}\n\nexport interface ScenarioAssemblyState {\n  singleReject?: boolean;\n  quorum?: number;\n  subAssemblyStates?: ScenarioSubAssemblyState[];\n}\n\nexport interface ScenarioSubAssemblyState {\n  singleReject?: boolean;\n  quorum?: number;\n  approverStates?: ScenarioAssemblyApproverState[];\n}\n\nexport interface ScenarioAssemblyApproverState {\n  state?: TpClaimApproverState;\n}\n\nexport interface ScenarioReceiverNode extends Node, TimeStamped {\n  sharedKey?: KeyNode;\n  sharedCipherData?: string;\n  sharedCipherDataClearJson?: JSONObject;\n  pbk?: KeyNode;\n  receiverDirectories?: Connection<ScenarioReceiverDirectoryNode>;\n  receiverFiles?: Connection<ScenarioReceiverFileNode>;\n  tp?: TpNode;\n}\n\nexport interface SharedScenarioReceiverNode extends Node, TimeStamped {\n  pbk?: KeyNode;\n}\n\nexport type ReceiverDirectoryAccessRole = AccessRoleChoice;\n\nexport interface ScenarioReceiverItemNode extends Node, TimeStamped {\n  receiver?: SharedScenarioReceiverNode;\n  sharedKey?: KeyNode;\n  sharedCipherData?: string;\n  sharedCipherDataClearJson?: JSONObject;\n  accessRole?: ReceiverDirectoryAccessRole;\n  wrappedItemKey?: string;\n  itemKey?: KeyNode;\n}\n\nexport interface ScenarioReceiverDirectoryNode\n  extends ScenarioReceiverItemNode {\n  directory?: DirectoryNode;\n}\n\nexport interface ScenarioReceiverFileNode extends ScenarioReceiverItemNode {\n  file?: FileNode;\n}\n\nexport interface ScenarioClaimantNode extends Node, TimeStamped {\n  tp?: TpNode;\n  sharedKey?: KeyNode;\n  sharedCipherData?: string;\n  sharedCipherDataClearJson?: JSONObject;\n}\n\nexport interface SharedScenarioNode extends Node, TimeStamped {\n  subject?: UserNode;\n  state?: ScenarioState;\n  tp?: TpNode;\n  asClaimant?: ScenarioClaimantNode;\n  asReceiver?: ScenarioReceiverNode;\n  assembly?: SharedTpAssemblyNode;\n  sharedClaim?: SharedScenarioClaimNode;\n  assemblyState?: ScenarioAssemblyState;\n  latestClaim?: ScenarioLatestClaim;\n}\n\nexport interface SharedScenarioClaimNode extends Node, TimeStamped {\n  state?: ClaimState;\n  sharedScenario?: SharedScenarioNode;\n  isClaimant?: boolean;\n  asClaimReceiver?: SharedScenarioClaimReceiverNode;\n  claim: SharedTpClaimNode;\n}\n\nexport interface SharedScenarioClaimApproverNode extends Node, TimeStamped {\n  receivers?: Connection<SharedScenarioReceiverNode>;\n  state?: ClaimApproverState;\n  approver?: TpAssemblyApproverNode;\n}\n\nexport interface SharedScenarioClaimReceiverNode extends Node, TimeStamped {\n  received?: DateTime;\n  approvals?: Connection<SharedScenarioClaimReceivedApprovalNode>;\n}\n\nexport interface SharedScenarioClaimReceivedApprovalNode\n  extends Node,\n    TimeStamped {\n  receiverCipher?: string;\n  receiverCipherPartialAssemblyKey?: string;\n  pxk?: KeyNode;\n}\n\nexport interface NotificationNode extends Node, TimeStamped {\n  plainData?: JSONString;\n  plainMeta?: JSONString;\n  timeRead?: DateTime;\n}\n\nexport interface NotificationManagementState extends Node, TimeStamped {\n  lastViewed?: DateTime;\n}\n\nexport enum LinkTypeField {\n  HARD = 'HARD',\n  SOFT = 'SOFT',\n}\n"]}
119
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lr-graphql.types.js","sourceRoot":"","sources":["../../../../../../../projects/core/src/lib/api/types/lr-graphql.types.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Connection,\n  DateTime,\n  GenericScalar,\n  ID,\n  JSONObject,\n  JSONString,\n  LrEmail,\n  Node,\n  TimeStamped,\n} from './graphql.types';\n\nexport function mapEdges<T>(connection: Connection<T>) {\n  return connection.edges.map((edge) => edge.node);\n}\n\nexport interface FeaturesNode {\n  myVault: string[];\n  tpVault: string[];\n  shareVault: string[];\n}\n\nexport enum UserDeleteState {\n  REQUESTED = 'REQUESTED',\n}\n\nexport interface UserDeleteNode extends Node, TimeStamped {\n  state?: UserDeleteState;\n}\n\nexport enum PlanState {\n  ENABLED = 'ENABLED',\n  DISABLED = 'DISABLED',\n}\n\nexport interface PlanNode extends Node {\n  name?: string;\n  data?: JSONString;\n  state?: PlanState;\n}\n\nexport interface UserPlanStripeNode extends Node, TimeStamped {\n  subscriptionId?: string;\n  priceId?: string;\n}\n\nexport interface UserPlanNode extends Node, TimeStamped {\n  user?: UserNode;\n  plan?: PlanNode;\n  periodEnd?: DateTime;\n  stripe?: UserPlanStripeNode;\n  issuer?: UserNode;\n}\n\nexport interface UserStripeNode extends Node, TimeStamped {\n  customer?: GenericScalar;\n}\n\nexport interface PassKeyNode extends Node, TimeStamped {\n  passKeyParams?: GenericScalar;\n  passIdpParams?: GenericScalar;\n  wrappedPassIdpVerifierPrk?: GenericScalar;\n}\n\nexport interface CurrentUserKeyNode extends Node, TimeStamped {\n  passKeys?: PassKeyNode[];\n  passKey?: PassKeyNode;\n  rootKey?: KeyNode;\n  masterKey?: KeyNode;\n  pxk?: KeyNode;\n  sigPxk?: KeyNode;\n}\n\n// ------------------------------------------------------\n// Node types\n// ------------------------------------------------------\nexport interface UserNode extends Node {\n  username?: string;\n  contactCards?: Connection<ContactCardNode>;\n  currentUserKey?: CurrentUserKeyNode;\n  ownedContactCard?: SharedContactCardNode;\n  receivedContactCard?: SharedContactCardNode;\n  isCurrentUser?: boolean;\n  haveTp?: boolean;\n  stripe?: UserStripeNode;\n  userPlans?: Connection<UserPlanNode>;\n  userDelete?: UserDeleteNode;\n  features?: FeaturesNode;\n  userFeatureState?: UserFeatureState;\n}\n\nexport interface UserFeatureState extends TimeStamped {\n  notificationsLastViewed?: DateTime;\n}\n\nexport interface ServerTime {\n  timestamp?: string;\n}\n\nexport interface KeyNode extends Node, TimeStamped {\n  pbk?: string;\n}\n\nexport interface ContactCardNode extends Node, TimeStamped {\n  owner?: UserNode;\n  publicDataSig?: string;\n  publicSearchableSig?: string;\n  sigPxk?: KeyNode;\n  defaultFrom?: DateTime;\n  publicData?: string;\n  publicSearchable?: string;\n  cipherData?: string;\n  cipherDataClearJson?: JSONObject;\n  key?: KeyNode;\n  plainData?: string;\n  plainDataSig?: string;\n}\n\nexport interface DirectoryNode extends Node, TimeStamped {\n  plainMeta?: JSONString;\n  plainMetaJson?: JSONObject;\n  cipherMeta?: string;\n  cipherMetaClearJson?: JSONObject;\n  archived?: boolean;\n  keyId?: ID;\n  childFileLinks?: Connection<FileLinkNode>;\n  childDirectoryLinks?: Connection<DirectoryLinkNode>;\n  parentDirectoryLinks?: Connection<DirectoryLinkNode>;\n  nParentDirectoryLinks?: DirectoryLinkNodeLrNList;\n  nChildDirectoryLinks?: DirectoryLinkNodeLrNList;\n  nChildFileLinks?: FileLinkNodeLrNList;\n  descendants?: Descendants;\n  accessRoles?: AccessRole[];\n}\n\nexport interface FileNode extends Node, TimeStamped {\n  currentVersion?: FileVersionNode;\n  archived?: boolean;\n  versions?: Connection<FileVersionNode>;\n  keyId?: ID;\n  parentDirectoryLinks?: Connection<FileLinkNode>;\n  nParentDirectoryLinks?: FileLinkNodeLrNList;\n  accessRoles?: AccessRole[];\n}\n\nexport interface DirectoryLinkNode extends Node, TimeStamped {\n  parentDirectory?: DirectoryNode;\n  childDirectory?: DirectoryNode;\n  linkType?: LinkTypeField;\n}\n\nexport interface FileLinkNode extends Node, TimeStamped {\n  parentDirectory?: DirectoryNode;\n  childFile?: FileNode;\n  linkType?: LinkTypeField;\n}\n\nexport interface DirectoryLinkNodeLrNList {\n  list?: DirectoryLinkNode[];\n}\n\nexport interface FileLinkNodeLrNList {\n  list?: FileLinkNode[];\n}\n\nexport interface Descendants {\n  directories?: Connection<DirectoryNode>;\n  files?: Connection<FileNode>;\n  directoriesCount?: number;\n  filesCount?: number;\n}\n\nexport enum AccessRoleChoice {\n  READER = 'READER',\n  WRITER = 'WRITER',\n  ADMIN = 'ADMIN',\n  DENY = 'DENY',\n  OWNER = 'OWNER',\n}\n\nexport enum AccessRoleMethod {\n  inherited = 'inherited',\n  direct = 'direct',\n}\n\nexport interface AccessRole {\n  issuer?: UserNode;\n  subject?: UserNode;\n  role?: AccessRoleChoice;\n  method?: AccessRoleMethod;\n  inheritedFrom?: DirectoryNode;\n  trustedParty?: TpNode;\n  isIssuer?: boolean;\n}\n\nexport enum FileOperationField {\n  CREATE = 'CREATE',\n  READ = 'READ',\n  UPDATE = 'UPDATE',\n  REVERT = 'REVERT',\n  DELETE = 'DELETE',\n}\n\nexport interface FileVersionNode extends Node, TimeStamped {\n  file?: FileNode;\n  state?: FileStateNode;\n  operation?: FileOperationField;\n  author?: UserNode;\n}\nexport interface FileStateNode extends Node, TimeStamped {\n  plainMeta?: JSONString;\n  plainMetaJson?: JSONObject;\n  cipherMeta?: string;\n  cipherMetaClearJson?: JSONObject;\n  contentResource?: string;\n  versions?: Connection<FileVersionNode>;\n  keyId: ID;\n}\n\nexport enum KeyExchangeOtkState {\n  OTK_INITIATED = 'OTK_INITIATED',\n  OTK_ACCEPTED = 'OTK_ACCEPTED',\n  OTK_COMPLETED = 'OTK_COMPLETED',\n}\n\nexport interface ContactCardSharedCipherData {\n  // Shared read access between initiator and responder. But only the initiator has write access.\n  sharedCipherDataClearJson: JSONObject;\n}\n\n/**\n * The contents of the one-time key cipher\n */\nexport interface OtKeyCipherClearJson2 {\n  // Used to confirm to the initiator that the responder has access to the one-time key.\n  nonce: string;\n  // Data sent from initiator to the responder\n  initiator: {\n    oneTimePbk: Record<string, JSONObject>; // one-time public encryption key the responder will use to send data back to the initiator\n    pbk: Record<string, JSONObject>; // public encryption key\n    sigPbk: Record<string, JSONObject>; // public signing key\n    message?: JSONObject;\n    contactCard?: ContactCardSharedCipherData;\n  };\n}\n\nexport interface KeyExchangeOtkNode extends Node, TimeStamped {\n  state?: KeyExchangeOtkState;\n  sharedKey?: KeyNode;\n  mkSharedKey?: KeyNode;\n  initiatorSigPxk?: KeyNode;\n  responderSigPxk?: KeyNode;\n  initiatorOneTimePbkCipher?: string;\n  otKeyParams?: string;\n  otKeyCipher?: string;\n  otKeyCipherClearJson?: OtKeyCipherClearJson2;\n  responderPbkCipher?: string;\n}\n\nexport enum KeyExchangeState {\n  IN_PROGRESS = 'IN_PROGRESS',\n  COMPLETED = 'COMPLETED',\n  DECLINED = 'DECLINED',\n  CANCELLED = 'CANCELLED',\n  DELETED = 'DELETED',\n}\n\nexport enum KeyExchangeMode {\n  OTK = 'OTK',\n}\n\nexport interface KeyExchangeNode extends Node, TimeStamped {\n  expiryTime?: DateTime;\n  token?: string;\n  tokenExpiryTime?: DateTime;\n  state?: KeyExchangeState;\n  mode?: KeyExchangeMode;\n  initiator?: UserNode;\n  responder?: UserNode;\n  initiatorRootKeyCipher?: string;\n  responderRootKeyCipher?: string;\n  initiatorActionRequired?: boolean;\n  responderActionRequired?: boolean;\n  createTp?: boolean;\n  otk?: KeyExchangeOtkNode;\n  isInitiator?: boolean;\n  isExpired?: boolean;\n  responderEmailAddress?: LrEmail;\n}\n\nexport interface SharedItems {\n  directories?: Connection<DirectoryNode>;\n  files?: Connection<FileNode>;\n}\n\nexport interface SharedContactCardNode extends Node, TimeStamped {\n  owner?: UserNode;\n  receiver?: UserNode;\n  sharedKey?: KeyNode;\n  sharedCipherData?: string;\n  sharedCipherDataClearJson?: JSONObject;\n  sharedCipherDataSig?: string;\n  sharedCipherDataSigPxk?: KeyNode;\n  ownerCipherData?: string;\n  ownerCipherDataClearJson?: JSONObject;\n  ownerKey?: KeyNode;\n  ownerPlainData?: string;\n  ownerPlainDataJson?: JSONObject;\n  ownerPlainDataSig?: string;\n  receiverCipherData?: string;\n  receiverCipherDataClearJson?: JSONObject;\n  receiverKey?: KeyNode;\n}\n\nexport interface UserSharedKeyNode extends Node, TimeStamped {\n  keyExchange?: KeyExchangeNode;\n  user?: UserNode;\n  userPrk?: KeyNode;\n  userSigPrk?: KeyNode;\n  other?: UserNode;\n  otherPbk?: KeyNode;\n  otherSigPbk?: KeyNode;\n  sharedKey?: KeyNode;\n  mkSharedKey?: KeyNode;\n  mkPxk?: KeyNode;\n  mkReshareRequestCipher?: string;\n  mkReshareResponseCipher?: string;\n  mkReshareRequestCipherClearJson?: JSONObject;\n  mkReshareResponseCipherClearJson?: JSONObject;\n  mkReshareRequestSent?: boolean;\n  mkReshareResponseSent?: boolean;\n}\n\nexport interface CurrentUserSharedKeyNode extends Node, TimeStamped {\n  user?: UserNode;\n  other?: UserNode;\n  userSharedKey?: UserSharedKeyNode;\n}\n\nexport interface TpNode extends Node, TimeStamped {\n  user?: UserNode;\n  other?: UserNode;\n  currentUserSharedKey?: CurrentUserSharedKeyNode;\n  isCompleted?: boolean;\n  sharedKey?: KeyNode;\n  sharedContactCard?: SharedContactCardNode;\n  myContactCard?: SharedContactCardNode;\n  myItems?: SharedItems;\n  sharedItems?: SharedItems;\n  myScenarios?: Connection<ScenarioNode>;\n  sharedScenarios?: Connection<SharedScenarioNode>;\n}\n\nexport enum TpAssemblyState {\n  DISABLED = 'DISABLED',\n  ENABLED = 'ENABLED',\n  CLAIMED = 'CLAIMED',\n  APPROVED = 'APPROVED',\n  REJECTED = 'REJECTED',\n  EXPIRED = 'EXPIRED',\n  CANCELLED = 'CANCELLED',\n  RESET = 'RESET',\n}\n\nexport enum TpClaimState {\n  CLAIMED = 'CLAIMED',\n  APPROVED = 'APPROVED',\n  REJECTED = 'REJECTED',\n  EXPIRED = 'EXPIRED',\n  CANCELLED = 'CANCELLED',\n  RESET = 'RESET',\n}\n\nexport enum TpClaimApproverState {\n  CLAIMED = 'CLAIMED',\n  APPROVED = 'APPROVED',\n  REJECTED = 'REJECTED',\n}\n\nexport interface TpPasswordResetApproval extends Node, TimeStamped {\n  approverEmail?: string;\n  receiverCipher?: string;\n  receiverCipherClearJson?: JSONObject;\n  receiverCipherPartialAssemblyKey?: string;\n  receiverCipherPartialAssemblyKeyClearJson?: JSONObject;\n}\n\nexport interface TpPasswordResetUserApprovalNode extends Node, TimeStamped {\n  receiverCipher?: string;\n  receiverCipherClearJson?: JSONObject;\n  receiverCipherPartialAssemblyKey?: string;\n  receiverCipherPartialAssemblyKeyClearJson?: JSONObject;\n  approverEmail?: string;\n}\n\nexport interface TpPasswordResetUserApprover {\n  name?: string;\n  email?: string;\n  state?: TpClaimApproverState;\n}\n\nexport interface TpPasswordResetUserSubAssembly {\n  singleReject?: boolean;\n  quorum?: number;\n  approvers?: TpPasswordResetUserApprover[];\n}\n\nexport interface TpPasswordResetUserAssembly {\n  singleReject?: boolean;\n  quorum?: number;\n  subAssemblies?: TpPasswordResetUserSubAssembly[];\n}\n\nexport interface TpPasswordResetUserNode {\n  username?: string;\n  resetUsername?: string;\n  state?: TpClaimState;\n  passKey?: PassKeyNode;\n  masterKey?: KeyNode;\n  pxk?: KeyNode;\n  sessionEncryptionKey?: string;\n  approvals?: TpPasswordResetUserApprovalNode[];\n  assemblyCipherData?: string;\n  wrappedAssemblyKeyVerifierPrk?: string;\n  assembly?: TpPasswordResetUserAssembly;\n}\n\nexport interface TpPasswordResetNode extends Node, TimeStamped {\n  assembly?: TpAssemblyNode;\n  request?: TpPasswordResetRequestNode;\n  applied?: boolean;\n}\n\nexport interface TpPasswordResetRequestNode extends Node, TimeStamped {\n  state?: TpClaimState;\n}\n\nexport interface TpAssemblyNode extends Node, TimeStamped {\n  id?: ID;\n  singleReject?: boolean;\n  quorum?: number;\n  subjectKey?: KeyNode;\n  subjectCipherData?: string;\n  subjectCipherDataClearJson?: JSONObject;\n  assemblyKey?: KeyNode;\n  assemblyCipherData?: string;\n  assemblyCipherDataClearJson?: JSONObject;\n  subAssemblies?: Connection<TpSubAssemblyNode>;\n}\n\nexport interface TpSubAssemblyNode extends Node, TimeStamped {\n  singleReject?: boolean;\n  quorum?: number;\n  subjectCipherData?: string;\n  subjectCipherDataClearJson?: string;\n  approvers?: Connection<TpAssemblyApproverNode>;\n}\n\nexport interface TpAssemblyApproverNode extends Node, TimeStamped {\n  sharedKey?: KeyNode;\n  sharedCipherData?: string;\n  sharedCipherDataClearJson?: JSONObject;\n  sharedCipherApprovalData?: string;\n  sharedCipherApprovalDataClearJson?: JSONObject;\n  tp?: TpNode;\n}\n\nexport interface SharedTpPasswordResetNode extends Node, TimeStamped {\n  assembly?: SharedTpAssemblyNode;\n  tp?: TpNode;\n  sharedRequest?: SharedTpPasswordResetRequestNode;\n}\n\nexport interface SharedTpAssemblyNode extends Node, TimeStamped {\n  asApprovers?: Connection<TpAssemblyAsApproverNode>;\n}\n\nexport interface TpAssemblyAsApproverNode extends Node, TimeStamped {\n  sharedKey?: KeyNode;\n  sharedCipherData?: string;\n}\n\nexport interface SharedTpPasswordResetRequestNode extends Node, TimeStamped {\n  claim?: SharedTpClaimNode;\n  pxk?: KeyNode;\n}\n\nexport interface SharedTpClaimNode extends Node, TimeStamped {\n  state?: TpClaimState;\n  asClaimApprovers?: Connection<SharedTpClaimApproverNode>;\n}\n\nexport interface SharedTpClaimApproverNode extends Node, TimeStamped {\n  state?: TpClaimApproverState;\n  sharedKey?: KeyNode;\n  sharedCipherApprovalData?: string;\n  sharedCipherApprovalDataClearJson?: JSONObject;\n  sharedCipherPartialAssemblyKey?: string;\n  sharedCipherPartialAssemblyKeyClearJson?: JSONObject;\n  receiverApprovals?: Connection<SharedTpClaimReceiverApprovalNode>;\n}\n\nexport interface SharedTpClaimReceiverApprovalNode extends Node, TimeStamped {\n  pxk?: KeyNode;\n}\n\nexport enum LockState {\n  UNLOCKED = 'UNLOCKED',\n  MUTEX_LOCKED = 'MUTEX_LOCKED',\n}\n\nexport enum ScenarioState {\n  DISABLED = 'DISABLED',\n  ENABLED = 'ENABLED',\n  CLAIMED = 'CLAIMED',\n  APPROVED = 'APPROVED',\n}\n\nexport enum ClaimState {\n  CLAIMED = 'CLAIMED',\n  EXPIRED = 'EXPIRED',\n  APPROVED = 'APPROVED',\n  REJECTED = 'REJECTED',\n  CANCELLED = 'CANCELLED',\n  RESET = 'RESET',\n}\n\nexport enum ClaimApproverState {\n  CLAIMED = 'CLAIMED',\n  APPROVED = 'APPROVED',\n  REJECTED = 'REJECTED',\n}\n\nexport enum ScenarioLastClaimState {\n  CLAIMED = 'CLAIMED',\n  APPROVED = 'APPROVED',\n  REJECTED = 'REJECTED',\n  EXPIRED = 'EXPIRED',\n  CANCELLED = 'CANCELLED',\n  RESET = 'RESET',\n}\n\nexport interface ScenarioLatestClaim {\n  state?: ScenarioLastClaimState;\n  created?: DateTime;\n  claimAgainAfter?: DateTime;\n}\n\nexport interface ScenarioNode extends Node, TimeStamped {\n  subject?: UserNode;\n  subjectKey?: KeyNode;\n  subjectCipherData?: string;\n  subjectCipherDataClearJson?: JSONObject;\n  assembly?: TpAssemblyNode;\n  state?: ScenarioState;\n  claimants?: Connection<ScenarioClaimantNode>;\n  receivers?: Connection<ScenarioReceiverNode>;\n  claims?: Connection<ScenarioClaimNode>;\n  claim?: ScenarioClaimNode;\n  assemblyState?: ScenarioAssemblyState;\n  latestClaim?: ScenarioLatestClaim;\n}\n\nexport interface ScenarioClaimNode extends Node, TimeStamped {\n  claimant?: ScenarioClaimantNode;\n  state?: ClaimState;\n  scenario?: ScenarioNode;\n}\n\nexport interface ScenarioAssemblyState {\n  singleReject?: boolean;\n  quorum?: number;\n  subAssemblyStates?: ScenarioSubAssemblyState[];\n}\n\nexport interface ScenarioSubAssemblyState {\n  singleReject?: boolean;\n  quorum?: number;\n  approverStates?: ScenarioAssemblyApproverState[];\n}\n\nexport interface ScenarioAssemblyApproverState {\n  state?: TpClaimApproverState;\n}\n\nexport interface ScenarioReceiverNode extends Node, TimeStamped {\n  sharedKey?: KeyNode;\n  sharedCipherData?: string;\n  sharedCipherDataClearJson?: JSONObject;\n  pbk?: KeyNode;\n  receiverDirectories?: Connection<ScenarioReceiverDirectoryNode>;\n  receiverFiles?: Connection<ScenarioReceiverFileNode>;\n  tp?: TpNode;\n}\n\nexport interface SharedScenarioReceiverNode extends Node, TimeStamped {\n  pbk?: KeyNode;\n}\n\nexport type ReceiverDirectoryAccessRole = AccessRoleChoice;\n\nexport interface ScenarioReceiverItemNode extends Node, TimeStamped {\n  receiver?: SharedScenarioReceiverNode;\n  sharedKey?: KeyNode;\n  sharedCipherData?: string;\n  sharedCipherDataClearJson?: JSONObject;\n  accessRole?: ReceiverDirectoryAccessRole;\n  wrappedItemKey?: string;\n  itemKey?: KeyNode;\n}\n\nexport interface ScenarioReceiverDirectoryNode\n  extends ScenarioReceiverItemNode {\n  directory?: DirectoryNode;\n}\n\nexport interface ScenarioReceiverFileNode extends ScenarioReceiverItemNode {\n  file?: FileNode;\n}\n\nexport interface ScenarioClaimantNode extends Node, TimeStamped {\n  tp?: TpNode;\n  sharedKey?: KeyNode;\n  sharedCipherData?: string;\n  sharedCipherDataClearJson?: JSONObject;\n}\n\nexport interface SharedScenarioNode extends Node, TimeStamped {\n  subject?: UserNode;\n  state?: ScenarioState;\n  tp?: TpNode;\n  asClaimant?: ScenarioClaimantNode;\n  asReceiver?: ScenarioReceiverNode;\n  assembly?: SharedTpAssemblyNode;\n  sharedClaim?: SharedScenarioClaimNode;\n  assemblyState?: ScenarioAssemblyState;\n  latestClaim?: ScenarioLatestClaim;\n}\n\nexport interface SharedScenarioClaimNode extends Node, TimeStamped {\n  state?: ClaimState;\n  sharedScenario?: SharedScenarioNode;\n  isClaimant?: boolean;\n  asClaimReceiver?: SharedScenarioClaimReceiverNode;\n  claim: SharedTpClaimNode;\n}\n\nexport interface SharedScenarioClaimApproverNode extends Node, TimeStamped {\n  receivers?: Connection<SharedScenarioReceiverNode>;\n  state?: ClaimApproverState;\n  approver?: TpAssemblyApproverNode;\n}\n\nexport interface SharedScenarioClaimReceiverNode extends Node, TimeStamped {\n  received?: DateTime;\n  approvals?: Connection<SharedScenarioClaimReceivedApprovalNode>;\n}\n\nexport interface SharedScenarioClaimReceivedApprovalNode\n  extends Node,\n    TimeStamped {\n  receiverCipher?: string;\n  receiverCipherPartialAssemblyKey?: string;\n  pxk?: KeyNode;\n}\n\nexport interface NotificationNode extends Node, TimeStamped {\n  plainData?: JSONString;\n  plainMeta?: JSONString;\n  timeRead?: DateTime;\n}\n\nexport interface NotificationManagementState extends Node, TimeStamped {\n  lastViewed?: DateTime;\n}\n\nexport enum LinkTypeField {\n  HARD = 'HARD',\n  SOFT = 'SOFT',\n}\n\nexport interface MessageNode extends Node, TimeStamped {\n  sender?: UserNode;\n  receiver?: UserNode;\n  sharedKey?: KeyNode;\n  senderSigPbk?: KeyNode;\n  plainMessage?: string;\n  plainMessageJson?: string;\n  signedCipherMessage?: string;\n  signedCipherMessageClearJson?: string;\n}\n"]}
@@ -54,4 +54,4 @@ export const configureAmplifyAuth = ({ authUrl: authUrl, userPoolId, userPoolWeb
54
54
  });
55
55
  };
56
56
  };
57
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC5jb25maWcuanMiLCJzb3VyY2VSb290IjoiL29wdC9hdGxhc3NpYW4vcGlwZWxpbmVzL2FnZW50L2J1aWxkL3Byb2plY3RzL2NvcmUvc3JjLyIsInNvdXJjZXMiOlsibGliL2F1dGgvYXV0aC5jb25maWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR0EsTUFBTSxVQUFVLHFCQUFxQixDQUNuQyxNQUE2RDtJQUU3RCxPQUFPLElBQUksT0FBTyxDQUFJLENBQUMsT0FBTyxFQUFFLE1BQU0sRUFBRSxFQUFFLENBQ3hDLE1BQU0sQ0FBQyxDQUFDLEdBQUcsRUFBRSxNQUFNLEVBQUUsRUFBRSxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQy9ELENBQUM7QUFDSixDQUFDO0FBRUQsTUFBTSxDQUFDLE1BQU0sUUFBUSxHQUFHLENBQUMsT0FBZSxFQUFFLEVBQUU7SUFDMUMsTUFBTSxLQUFLLEdBQUcsTUFBTSxDQUFDLEtBQUssQ0FBQztJQUUzQixPQUFPLENBQUMsR0FBRyxFQUFFLE9BQU8sRUFBRSxFQUFFO1FBQ3RCLE1BQU0sSUFBSSxHQUFHLEdBQUcsRUFBRSxDQUFDLEtBQUssQ0FBQyxHQUFHLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFFdkMsSUFBSSxDQUFDLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLGNBQWMsQ0FBQyxFQUFFO1lBQ3BFLE9BQU8sSUFBSSxFQUFFLENBQUM7U0FDZjtRQUVELE1BQU0sU0FBUyxHQUFHLE9BQU8sQ0FBQyxPQUFPLENBQUMsY0FBYyxDQUFDLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQzdELElBQ0UsU0FBUyxDQUFDLE1BQU0sR0FBRyxDQUFDO1lBQ3BCLFNBQVMsQ0FBQyxDQUFDLENBQUMsS0FBSyxtQ0FBbUMsRUFDcEQ7WUFDQSxPQUFPLElBQUksRUFBRSxDQUFDO1NBQ2Y7UUFFRCxNQUFNLElBQUksR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUV0QyxJQUFJLElBQUksSUFBSSxJQUFJLENBQUMsY0FBYyxJQUFJLElBQUksQ0FBQyxjQUFjLENBQUMsT0FBTyxLQUFLLE1BQU0sRUFBRTtZQUN6RSxPQUFPLElBQUksRUFBRSxDQUFDO1NBQ2Y7UUFFRCxJQUFJLE1BQU0sR0FBRyxLQUFLLENBQUM7UUFFbkIsSUFBSSxTQUFTLENBQUMsQ0FBQyxDQUFDLEtBQUssd0JBQXdCLEVBQUU7WUFDN0MsSUFBSSxJQUFJLElBQUksSUFBSSxDQUFDLGFBQWEsS0FBSyx1QkFBdUIsRUFBRTtnQkFDMUQsT0FBTyxJQUFJLEVBQUUsQ0FBQzthQUNmO1lBQ0QsTUFBTSxHQUFHLElBQUksQ0FBQztTQUNmO2FBQU0sSUFBSSxTQUFTLENBQUMsQ0FBQyxDQUFDLEtBQUssY0FBYyxFQUFFO1lBQzFDLElBQUksSUFBSSxDQUFDLFFBQVEsS0FBSyxvQkFBb0IsRUFBRTtnQkFDMUMsTUFBTSxHQUFHLElBQUksQ0FBQzthQUNmO1NBQ0Y7UUFFRCxJQUFJLENBQUMsTUFBTSxFQUFFO1lBQ1gsT0FBTyxJQUFJLEVBQUUsQ0FBQztTQUNmO1FBRUQsT0FBTyxLQUFLLENBQUMsR0FBRyxPQUFPLGFBQWEsa0NBQy9CLE9BQU8sS0FDVixXQUFXLEVBQUUsU0FBUyxJQUN0QixDQUFDO0lBQ0wsQ0FBQyxDQUFDO0FBQ0osQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sb0JBQW9CLEdBQUcsQ0FDbEMsRUFBRSxPQUFPLEVBQUUsT0FBTyxFQUFFLFVBQVUsRUFBRSxtQkFBbUIsRUFBbUIsRUFDdEUsSUFBZSxFQUNmLEVBQUU7SUFDRixPQUFPLEdBQUcsRUFBRTtRQUNWLE1BQU0sTUFBTSxHQUFHLFVBQVUsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDckMsSUFBSSxNQUFNLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRTtZQUNyQixNQUFNLElBQUksS0FBSyxDQUFDLHdEQUF3RCxDQUFDLENBQUM7U0FDM0U7UUFFRCxNQUFNLENBQUMsS0FBSyxHQUFHLFFBQVEsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUVqQyxJQUFJLENBQUMsU0FBUyxDQUFDO1lBQ2IsbUNBQW1DO1lBQ25DLE1BQU0sRUFBRSxNQUFNLENBQUMsQ0FBQyxDQUFDO1lBQ2pCLHlDQUF5QztZQUN6QyxVQUFVO1lBQ1Ysd0VBQXdFO1lBQ3hFLG1CQUFtQjtZQUNuQixpRkFBaUY7WUFDakYsZUFBZSxFQUFFLEtBQUs7U0FDdkIsQ0FBQyxDQUFDO0lBQ0wsQ0FBQyxDQUFDO0FBQ0osQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQXV0aENsYXNzIH0gZnJvbSAnQGF3cy1hbXBsaWZ5L2F1dGgvbGliLWVzbS9BdXRoJztcbmltcG9ydCB7IExpZmVSZWFkeUNvbmZpZyB9IGZyb20gJy4uL2xpZmUtcmVhZHkuY29uZmlnJztcblxuZXhwb3J0IGZ1bmN0aW9uIGhhbmRsZUNvZ25pdG9DYWxsYmFjazxUPihcbiAgbWV0aG9kOiAoY2FsbGJhY2s6IChlcnI/OiBFcnJvciwgcmVzdWx0PzogVCkgPT4gdm9pZCkgPT4gdm9pZFxuKTogUHJvbWlzZTxUPiB7XG4gIHJldHVybiBuZXcgUHJvbWlzZTxUPigocmVzb2x2ZSwgcmVqZWN0KSA9PlxuICAgIG1ldGhvZCgoZXJyLCByZXN1bHQpID0+IChlcnIgPyByZWplY3QoZXJyKSA6IHJlc29sdmUocmVzdWx0KSkpXG4gICk7XG59XG5cbmV4cG9ydCBjb25zdCBhd3NGZXRjaCA9IChhdXRoVXJsOiBzdHJpbmcpID0+IHtcbiAgY29uc3QgZmV0Y2ggPSB3aW5kb3cuZmV0Y2g7XG5cbiAgcmV0dXJuICh1cmwsIG9wdGlvbnMpID0+IHtcbiAgICBjb25zdCBwYXNzID0gKCkgPT4gZmV0Y2godXJsLCBvcHRpb25zKTtcblxuICAgIGlmICghb3B0aW9ucyB8fCAhb3B0aW9ucy5oZWFkZXJzIHx8ICFvcHRpb25zLmhlYWRlcnNbJ1gtQW16LVRhcmdldCddKSB7XG4gICAgICByZXR1cm4gcGFzcygpO1xuICAgIH1cblxuICAgIGNvbnN0IG9wZXJhdGlvbiA9IG9wdGlvbnMuaGVhZGVyc1snWC1BbXotVGFyZ2V0J10uc3BsaXQoJy4nKTtcbiAgICBpZiAoXG4gICAgICBvcGVyYXRpb24ubGVuZ3RoIDwgMiB8fFxuICAgICAgb3BlcmF0aW9uWzBdICE9PSAnQVdTQ29nbml0b0lkZW50aXR5UHJvdmlkZXJTZXJ2aWNlJ1xuICAgICkge1xuICAgICAgcmV0dXJuIHBhc3MoKTtcbiAgICB9XG5cbiAgICBjb25zdCBib2R5ID0gSlNPTi5wYXJzZShvcHRpb25zLmJvZHkpO1xuXG4gICAgaWYgKGJvZHkgJiYgYm9keS5DbGllbnRNZXRhZGF0YSAmJiBib2R5LkNsaWVudE1ldGFkYXRhLm5vUHJveHkgPT09ICd0cnVlJykge1xuICAgICAgcmV0dXJuIHBhc3MoKTtcbiAgICB9XG5cbiAgICBsZXQgY3VzdG9tID0gZmFsc2U7XG5cbiAgICBpZiAob3BlcmF0aW9uWzFdID09PSAnUmVzcG9uZFRvQXV0aENoYWxsZW5nZScpIHtcbiAgICAgIGlmIChib2R5ICYmIGJvZHkuQ2hhbGxlbmdlTmFtZSA9PT0gJ05FV19QQVNTV09SRF9SRVFVSVJFRCcpIHtcbiAgICAgICAgcmV0dXJuIHBhc3MoKTtcbiAgICAgIH1cbiAgICAgIGN1c3RvbSA9IHRydWU7XG4gICAgfSBlbHNlIGlmIChvcGVyYXRpb25bMV0gPT09ICdJbml0aWF0ZUF1dGgnKSB7XG4gICAgICBpZiAoYm9keS5BdXRoRmxvdyA9PT0gJ1JFRlJFU0hfVE9LRU5fQVVUSCcpIHtcbiAgICAgICAgY3VzdG9tID0gdHJ1ZTtcbiAgICAgIH1cbiAgICB9XG5cbiAgICBpZiAoIWN1c3RvbSkge1xuICAgICAgcmV0dXJuIHBhc3MoKTtcbiAgICB9XG5cbiAgICByZXR1cm4gZmV0Y2goYCR7YXV0aFVybH1hdXRoL3Byb3h5L2AsIHtcbiAgICAgIC4uLm9wdGlvbnMsXG4gICAgICBjcmVkZW50aWFsczogJ2luY2x1ZGUnLFxuICAgIH0pO1xuICB9O1xufTtcblxuZXhwb3J0IGNvbnN0IGNvbmZpZ3VyZUFtcGxpZnlBdXRoID0gKFxuICB7IGF1dGhVcmw6IGF1dGhVcmwsIHVzZXJQb29sSWQsIHVzZXJQb29sV2ViQ2xpZW50SWQgfTogTGlmZVJlYWR5Q29uZmlnLFxuICBhdXRoOiBBdXRoQ2xhc3NcbikgPT4ge1xuICByZXR1cm4gKCkgPT4ge1xuICAgIGNvbnN0IHRva2VucyA9IHVzZXJQb29sSWQuc3BsaXQoJ18nKTtcbiAgICBpZiAodG9rZW5zLmxlbmd0aCA8IDIpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcigndXNlclBvb2xJZCBzaG91bGQgaGF2ZSB0aGlzIGZvcm1hdDoge2F3cy1yZWdpb259X3h4eHh4Jyk7XG4gICAgfVxuXG4gICAgd2luZG93LmZldGNoID0gYXdzRmV0Y2goYXV0aFVybCk7XG5cbiAgICBhdXRoLmNvbmZpZ3VyZSh7XG4gICAgICAvLyBSRVFVSVJFRCAtIEFtYXpvbiBDb2duaXRvIFJlZ2lvblxuICAgICAgcmVnaW9uOiB0b2tlbnNbMF0sXG4gICAgICAvLyBPUFRJT05BTCAtIEFtYXpvbiBDb2duaXRvIFVzZXIgUG9vbCBJRFxuICAgICAgdXNlclBvb2xJZCxcbiAgICAgIC8vIE9QVElPTkFMIC0gQW1hem9uIENvZ25pdG8gV2ViIENsaWVudCBJRCAoMjYtY2hhciBhbHBoYW51bWVyaWMgc3RyaW5nKVxuICAgICAgdXNlclBvb2xXZWJDbGllbnRJZCxcbiAgICAgIC8vIE9QVElPTkFMIC0gRW5mb3JjZSB1c2VyIGF1dGhlbnRpY2F0aW9uIHByaW9yIHRvIGFjY2Vzc2luZyBBV1MgcmVzb3VyY2VzIG9yIG5vdFxuICAgICAgbWFuZGF0b3J5U2lnbkluOiBmYWxzZSxcbiAgICB9KTtcbiAgfTtcbn07XG4iXX0=
57
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC5jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3NyYy9saWIvYXV0aC9hdXRoLmNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHQSxNQUFNLFVBQVUscUJBQXFCLENBQ25DLE1BQTZEO0lBRTdELE9BQU8sSUFBSSxPQUFPLENBQUksQ0FBQyxPQUFPLEVBQUUsTUFBTSxFQUFFLEVBQUUsQ0FDeEMsTUFBTSxDQUFDLENBQUMsR0FBRyxFQUFFLE1BQU0sRUFBRSxFQUFFLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FDL0QsQ0FBQztBQUNKLENBQUM7QUFFRCxNQUFNLENBQUMsTUFBTSxRQUFRLEdBQUcsQ0FBQyxPQUFlLEVBQUUsRUFBRTtJQUMxQyxNQUFNLEtBQUssR0FBRyxNQUFNLENBQUMsS0FBSyxDQUFDO0lBRTNCLE9BQU8sQ0FBQyxHQUFHLEVBQUUsT0FBTyxFQUFFLEVBQUU7UUFDdEIsTUFBTSxJQUFJLEdBQUcsR0FBRyxFQUFFLENBQUMsS0FBSyxDQUFDLEdBQUcsRUFBRSxPQUFPLENBQUMsQ0FBQztRQUV2QyxJQUFJLENBQUMsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsY0FBYyxDQUFDLEVBQUU7WUFDcEUsT0FBTyxJQUFJLEVBQUUsQ0FBQztTQUNmO1FBRUQsTUFBTSxTQUFTLEdBQUcsT0FBTyxDQUFDLE9BQU8sQ0FBQyxjQUFjLENBQUMsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDN0QsSUFDRSxTQUFTLENBQUMsTUFBTSxHQUFHLENBQUM7WUFDcEIsU0FBUyxDQUFDLENBQUMsQ0FBQyxLQUFLLG1DQUFtQyxFQUNwRDtZQUNBLE9BQU8sSUFBSSxFQUFFLENBQUM7U0FDZjtRQUVELE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBRXRDLElBQUksSUFBSSxJQUFJLElBQUksQ0FBQyxjQUFjLElBQUksSUFBSSxDQUFDLGNBQWMsQ0FBQyxPQUFPLEtBQUssTUFBTSxFQUFFO1lBQ3pFLE9BQU8sSUFBSSxFQUFFLENBQUM7U0FDZjtRQUVELElBQUksTUFBTSxHQUFHLEtBQUssQ0FBQztRQUVuQixJQUFJLFNBQVMsQ0FBQyxDQUFDLENBQUMsS0FBSyx3QkFBd0IsRUFBRTtZQUM3QyxJQUFJLElBQUksSUFBSSxJQUFJLENBQUMsYUFBYSxLQUFLLHVCQUF1QixFQUFFO2dCQUMxRCxPQUFPLElBQUksRUFBRSxDQUFDO2FBQ2Y7WUFDRCxNQUFNLEdBQUcsSUFBSSxDQUFDO1NBQ2Y7YUFBTSxJQUFJLFNBQVMsQ0FBQyxDQUFDLENBQUMsS0FBSyxjQUFjLEVBQUU7WUFDMUMsSUFBSSxJQUFJLENBQUMsUUFBUSxLQUFLLG9CQUFvQixFQUFFO2dCQUMxQyxNQUFNLEdBQUcsSUFBSSxDQUFDO2FBQ2Y7U0FDRjtRQUVELElBQUksQ0FBQyxNQUFNLEVBQUU7WUFDWCxPQUFPLElBQUksRUFBRSxDQUFDO1NBQ2Y7UUFFRCxPQUFPLEtBQUssQ0FBQyxHQUFHLE9BQU8sYUFBYSxrQ0FDL0IsT0FBTyxLQUNWLFdBQVcsRUFBRSxTQUFTLElBQ3RCLENBQUM7SUFDTCxDQUFDLENBQUM7QUFDSixDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxvQkFBb0IsR0FBRyxDQUNsQyxFQUFFLE9BQU8sRUFBRSxPQUFPLEVBQUUsVUFBVSxFQUFFLG1CQUFtQixFQUFtQixFQUN0RSxJQUFlLEVBQ2YsRUFBRTtJQUNGLE9BQU8sR0FBRyxFQUFFO1FBQ1YsTUFBTSxNQUFNLEdBQUcsVUFBVSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUNyQyxJQUFJLE1BQU0sQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFO1lBQ3JCLE1BQU0sSUFBSSxLQUFLLENBQUMsd0RBQXdELENBQUMsQ0FBQztTQUMzRTtRQUVELE1BQU0sQ0FBQyxLQUFLLEdBQUcsUUFBUSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBRWpDLElBQUksQ0FBQyxTQUFTLENBQUM7WUFDYixtQ0FBbUM7WUFDbkMsTUFBTSxFQUFFLE1BQU0sQ0FBQyxDQUFDLENBQUM7WUFDakIseUNBQXlDO1lBQ3pDLFVBQVU7WUFDVix3RUFBd0U7WUFDeEUsbUJBQW1CO1lBQ25CLGlGQUFpRjtZQUNqRixlQUFlLEVBQUUsS0FBSztTQUN2QixDQUFDLENBQUM7SUFDTCxDQUFDLENBQUM7QUFDSixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBdXRoQ2xhc3MgfSBmcm9tICdAYXdzLWFtcGxpZnkvYXV0aC9saWItZXNtL0F1dGgnO1xuaW1wb3J0IHsgTGlmZVJlYWR5Q29uZmlnIH0gZnJvbSAnLi4vbGlmZS1yZWFkeS5jb25maWcnO1xuXG5leHBvcnQgZnVuY3Rpb24gaGFuZGxlQ29nbml0b0NhbGxiYWNrPFQ+KFxuICBtZXRob2Q6IChjYWxsYmFjazogKGVycj86IEVycm9yLCByZXN1bHQ/OiBUKSA9PiB2b2lkKSA9PiB2b2lkXG4pOiBQcm9taXNlPFQ+IHtcbiAgcmV0dXJuIG5ldyBQcm9taXNlPFQ+KChyZXNvbHZlLCByZWplY3QpID0+XG4gICAgbWV0aG9kKChlcnIsIHJlc3VsdCkgPT4gKGVyciA/IHJlamVjdChlcnIpIDogcmVzb2x2ZShyZXN1bHQpKSlcbiAgKTtcbn1cblxuZXhwb3J0IGNvbnN0IGF3c0ZldGNoID0gKGF1dGhVcmw6IHN0cmluZykgPT4ge1xuICBjb25zdCBmZXRjaCA9IHdpbmRvdy5mZXRjaDtcblxuICByZXR1cm4gKHVybCwgb3B0aW9ucykgPT4ge1xuICAgIGNvbnN0IHBhc3MgPSAoKSA9PiBmZXRjaCh1cmwsIG9wdGlvbnMpO1xuXG4gICAgaWYgKCFvcHRpb25zIHx8ICFvcHRpb25zLmhlYWRlcnMgfHwgIW9wdGlvbnMuaGVhZGVyc1snWC1BbXotVGFyZ2V0J10pIHtcbiAgICAgIHJldHVybiBwYXNzKCk7XG4gICAgfVxuXG4gICAgY29uc3Qgb3BlcmF0aW9uID0gb3B0aW9ucy5oZWFkZXJzWydYLUFtei1UYXJnZXQnXS5zcGxpdCgnLicpO1xuICAgIGlmIChcbiAgICAgIG9wZXJhdGlvbi5sZW5ndGggPCAyIHx8XG4gICAgICBvcGVyYXRpb25bMF0gIT09ICdBV1NDb2duaXRvSWRlbnRpdHlQcm92aWRlclNlcnZpY2UnXG4gICAgKSB7XG4gICAgICByZXR1cm4gcGFzcygpO1xuICAgIH1cblxuICAgIGNvbnN0IGJvZHkgPSBKU09OLnBhcnNlKG9wdGlvbnMuYm9keSk7XG5cbiAgICBpZiAoYm9keSAmJiBib2R5LkNsaWVudE1ldGFkYXRhICYmIGJvZHkuQ2xpZW50TWV0YWRhdGEubm9Qcm94eSA9PT0gJ3RydWUnKSB7XG4gICAgICByZXR1cm4gcGFzcygpO1xuICAgIH1cblxuICAgIGxldCBjdXN0b20gPSBmYWxzZTtcblxuICAgIGlmIChvcGVyYXRpb25bMV0gPT09ICdSZXNwb25kVG9BdXRoQ2hhbGxlbmdlJykge1xuICAgICAgaWYgKGJvZHkgJiYgYm9keS5DaGFsbGVuZ2VOYW1lID09PSAnTkVXX1BBU1NXT1JEX1JFUVVJUkVEJykge1xuICAgICAgICByZXR1cm4gcGFzcygpO1xuICAgICAgfVxuICAgICAgY3VzdG9tID0gdHJ1ZTtcbiAgICB9IGVsc2UgaWYgKG9wZXJhdGlvblsxXSA9PT0gJ0luaXRpYXRlQXV0aCcpIHtcbiAgICAgIGlmIChib2R5LkF1dGhGbG93ID09PSAnUkVGUkVTSF9UT0tFTl9BVVRIJykge1xuICAgICAgICBjdXN0b20gPSB0cnVlO1xuICAgICAgfVxuICAgIH1cblxuICAgIGlmICghY3VzdG9tKSB7XG4gICAgICByZXR1cm4gcGFzcygpO1xuICAgIH1cblxuICAgIHJldHVybiBmZXRjaChgJHthdXRoVXJsfWF1dGgvcHJveHkvYCwge1xuICAgICAgLi4ub3B0aW9ucyxcbiAgICAgIGNyZWRlbnRpYWxzOiAnaW5jbHVkZScsXG4gICAgfSk7XG4gIH07XG59O1xuXG5leHBvcnQgY29uc3QgY29uZmlndXJlQW1wbGlmeUF1dGggPSAoXG4gIHsgYXV0aFVybDogYXV0aFVybCwgdXNlclBvb2xJZCwgdXNlclBvb2xXZWJDbGllbnRJZCB9OiBMaWZlUmVhZHlDb25maWcsXG4gIGF1dGg6IEF1dGhDbGFzc1xuKSA9PiB7XG4gIHJldHVybiAoKSA9PiB7XG4gICAgY29uc3QgdG9rZW5zID0gdXNlclBvb2xJZC5zcGxpdCgnXycpO1xuICAgIGlmICh0b2tlbnMubGVuZ3RoIDwgMikge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCd1c2VyUG9vbElkIHNob3VsZCBoYXZlIHRoaXMgZm9ybWF0OiB7YXdzLXJlZ2lvbn1feHh4eHgnKTtcbiAgICB9XG5cbiAgICB3aW5kb3cuZmV0Y2ggPSBhd3NGZXRjaChhdXRoVXJsKTtcblxuICAgIGF1dGguY29uZmlndXJlKHtcbiAgICAgIC8vIFJFUVVJUkVEIC0gQW1hem9uIENvZ25pdG8gUmVnaW9uXG4gICAgICByZWdpb246IHRva2Vuc1swXSxcbiAgICAgIC8vIE9QVElPTkFMIC0gQW1hem9uIENvZ25pdG8gVXNlciBQb29sIElEXG4gICAgICB1c2VyUG9vbElkLFxuICAgICAgLy8gT1BUSU9OQUwgLSBBbWF6b24gQ29nbml0byBXZWIgQ2xpZW50IElEICgyNi1jaGFyIGFscGhhbnVtZXJpYyBzdHJpbmcpXG4gICAgICB1c2VyUG9vbFdlYkNsaWVudElkLFxuICAgICAgLy8gT1BUSU9OQUwgLSBFbmZvcmNlIHVzZXIgYXV0aGVudGljYXRpb24gcHJpb3IgdG8gYWNjZXNzaW5nIEFXUyByZXNvdXJjZXMgb3Igbm90XG4gICAgICBtYW5kYXRvcnlTaWduSW46IGZhbHNlLFxuICAgIH0pO1xuICB9O1xufTtcbiJdfQ==
@@ -1,31 +1,4 @@
1
- import gql from 'graphql-tag';
2
1
  import { gqlTyped } from '../_common/ast';
3
- export const PasswordChangeRequestMutation = gql `
4
- mutation {
5
- passwordChangeRequest(input: {}) {
6
- challenge
7
- }
8
- }
9
- `;
10
- export const PasswordChangeMutation = gql `
11
- mutation PasswordChange($input: PasswordChangeInput!) {
12
- passwordChange(input: $input) {
13
- token
14
- newPassKey {
15
- id
16
- }
17
- }
18
- }
19
- `;
20
- export const PasswordChangeConfigQuery = gql `
21
- query PasswordChangeConfigQuery {
22
- passwordChangeConfig {
23
- maxAuthAgeSeconds
24
- authTime
25
- serverTime
26
- }
27
- }
28
- `;
29
2
  export const SetSessionEncryptionKeyMutation = gqlTyped `
30
3
  mutation SetSessionEncryptionKeyMutation($input: SetSessionEncryptionKeyInput!) {
31
4
  setSessionEncryptionKey(input: $input) {
@@ -40,4 +13,4 @@ mutation ClearSessionEncryptionKeyMutation {
40
13
  }
41
14
  }
42
15
  `;
43
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC5ncWwuanMiLCJzb3VyY2VSb290IjoiL29wdC9hdGxhc3NpYW4vcGlwZWxpbmVzL2FnZW50L2J1aWxkL3Byb2plY3RzL2NvcmUvc3JjLyIsInNvdXJjZXMiOlsibGliL2F1dGgvYXV0aC5ncWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxHQUFHLE1BQU0sYUFBYSxDQUFDO0FBQzlCLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUUxQyxNQUFNLENBQUMsTUFBTSw2QkFBNkIsR0FBRyxHQUFHLENBQUE7Ozs7OztDQU0vQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sc0JBQXNCLEdBQUcsR0FBRyxDQUFBOzs7Ozs7Ozs7Q0FTeEMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLHlCQUF5QixHQUFHLEdBQUcsQ0FBQTs7Ozs7Ozs7Q0FRM0MsQ0FBQztBQU9GLE1BQU0sQ0FBQyxNQUFNLCtCQUErQixHQUFHLFFBQVEsQ0FBaUM7Ozs7OztDQU12RixDQUFDO0FBT0YsTUFBTSxDQUFDLE1BQU0saUNBQWlDLEdBQUcsUUFBUSxDQUFtQzs7Ozs7O0NBTTNGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgZ3FsIGZyb20gJ2dyYXBocWwtdGFnJztcbmltcG9ydCB7IGdxbFR5cGVkIH0gZnJvbSAnLi4vX2NvbW1vbi9hc3QnO1xuXG5leHBvcnQgY29uc3QgUGFzc3dvcmRDaGFuZ2VSZXF1ZXN0TXV0YXRpb24gPSBncWxgXG4gIG11dGF0aW9uIHtcbiAgICBwYXNzd29yZENoYW5nZVJlcXVlc3QoaW5wdXQ6IHt9KSB7XG4gICAgICBjaGFsbGVuZ2VcbiAgICB9XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBQYXNzd29yZENoYW5nZU11dGF0aW9uID0gZ3FsYFxuICBtdXRhdGlvbiBQYXNzd29yZENoYW5nZSgkaW5wdXQ6IFBhc3N3b3JkQ2hhbmdlSW5wdXQhKSB7XG4gICAgcGFzc3dvcmRDaGFuZ2UoaW5wdXQ6ICRpbnB1dCkge1xuICAgICAgdG9rZW5cbiAgICAgIG5ld1Bhc3NLZXkge1xuICAgICAgICBpZFxuICAgICAgfVxuICAgIH1cbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IFBhc3N3b3JkQ2hhbmdlQ29uZmlnUXVlcnkgPSBncWxgXG4gIHF1ZXJ5IFBhc3N3b3JkQ2hhbmdlQ29uZmlnUXVlcnkge1xuICAgIHBhc3N3b3JkQ2hhbmdlQ29uZmlnIHtcbiAgICAgIG1heEF1dGhBZ2VTZWNvbmRzXG4gICAgICBhdXRoVGltZVxuICAgICAgc2VydmVyVGltZVxuICAgIH1cbiAgfVxuYDtcblxuZXhwb3J0IGludGVyZmFjZSBTZXRTZXNzaW9uRW5jcnlwdGlvbktleU11dGF0aW9uIHtcbiAgc2V0U2Vzc2lvbkVuY3J5cHRpb25LZXk6IHtcbiAgICBzZXNzaW9uRW5jcnlwdGlvbktleTogc3RyaW5nO1xuICB9O1xufVxuZXhwb3J0IGNvbnN0IFNldFNlc3Npb25FbmNyeXB0aW9uS2V5TXV0YXRpb24gPSBncWxUeXBlZDxTZXRTZXNzaW9uRW5jcnlwdGlvbktleU11dGF0aW9uPmBcbm11dGF0aW9uIFNldFNlc3Npb25FbmNyeXB0aW9uS2V5TXV0YXRpb24oJGlucHV0OiBTZXRTZXNzaW9uRW5jcnlwdGlvbktleUlucHV0ISkge1xuICBzZXRTZXNzaW9uRW5jcnlwdGlvbktleShpbnB1dDogJGlucHV0KSB7XG4gICAgc2Vzc2lvbkVuY3J5cHRpb25LZXlcbiAgfVxufVxuYDtcblxuZXhwb3J0IGludGVyZmFjZSBDbGVhclNlc3Npb25FbmNyeXB0aW9uS2V5TXV0YXRpb24ge1xuICBjbGVhclNlc3Npb25FbmNyeXB0aW9uS2V5OiB7XG4gICAgc2Vzc2lvbkVuY3J5cHRpb25LZXk6IHN0cmluZztcbiAgfTtcbn1cbmV4cG9ydCBjb25zdCBDbGVhclNlc3Npb25FbmNyeXB0aW9uS2V5TXV0YXRpb24gPSBncWxUeXBlZDxDbGVhclNlc3Npb25FbmNyeXB0aW9uS2V5TXV0YXRpb24+YFxubXV0YXRpb24gQ2xlYXJTZXNzaW9uRW5jcnlwdGlvbktleU11dGF0aW9uIHtcbiAgY2xlYXJTZXNzaW9uRW5jcnlwdGlvbktleShpbnB1dDoge30pIHtcbiAgICBzZXNzaW9uRW5jcnlwdGlvbktleVxuICB9XG59XG5gO1xuIl19
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC5ncWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3NyYy9saWIvYXV0aC9hdXRoLmdxbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFPMUMsTUFBTSxDQUFDLE1BQU0sK0JBQStCLEdBQUcsUUFBUSxDQUFpQzs7Ozs7O0NBTXZGLENBQUM7QUFPRixNQUFNLENBQUMsTUFBTSxpQ0FBaUMsR0FBRyxRQUFRLENBQW1DOzs7Ozs7Q0FNM0YsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGdxbFR5cGVkIH0gZnJvbSAnLi4vX2NvbW1vbi9hc3QnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFNldFNlc3Npb25FbmNyeXB0aW9uS2V5TXV0YXRpb24ge1xuICBzZXRTZXNzaW9uRW5jcnlwdGlvbktleToge1xuICAgIHNlc3Npb25FbmNyeXB0aW9uS2V5OiBzdHJpbmc7XG4gIH07XG59XG5leHBvcnQgY29uc3QgU2V0U2Vzc2lvbkVuY3J5cHRpb25LZXlNdXRhdGlvbiA9IGdxbFR5cGVkPFNldFNlc3Npb25FbmNyeXB0aW9uS2V5TXV0YXRpb24+YFxubXV0YXRpb24gU2V0U2Vzc2lvbkVuY3J5cHRpb25LZXlNdXRhdGlvbigkaW5wdXQ6IFNldFNlc3Npb25FbmNyeXB0aW9uS2V5SW5wdXQhKSB7XG4gIHNldFNlc3Npb25FbmNyeXB0aW9uS2V5KGlucHV0OiAkaW5wdXQpIHtcbiAgICBzZXNzaW9uRW5jcnlwdGlvbktleVxuICB9XG59XG5gO1xuXG5leHBvcnQgaW50ZXJmYWNlIENsZWFyU2Vzc2lvbkVuY3J5cHRpb25LZXlNdXRhdGlvbiB7XG4gIGNsZWFyU2Vzc2lvbkVuY3J5cHRpb25LZXk6IHtcbiAgICBzZXNzaW9uRW5jcnlwdGlvbktleTogc3RyaW5nO1xuICB9O1xufVxuZXhwb3J0IGNvbnN0IENsZWFyU2Vzc2lvbkVuY3J5cHRpb25LZXlNdXRhdGlvbiA9IGdxbFR5cGVkPENsZWFyU2Vzc2lvbkVuY3J5cHRpb25LZXlNdXRhdGlvbj5gXG5tdXRhdGlvbiBDbGVhclNlc3Npb25FbmNyeXB0aW9uS2V5TXV0YXRpb24ge1xuICBjbGVhclNlc3Npb25FbmNyeXB0aW9uS2V5KGlucHV0OiB7fSkge1xuICAgIHNlc3Npb25FbmNyeXB0aW9uS2V5XG4gIH1cbn1cbmA7XG4iXX0=