@lifeready/core 1.0.1 → 1.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (380) hide show
  1. package/README.md +62 -62
  2. package/bundles/lifeready-core.umd.js +15939 -0
  3. package/bundles/lifeready-core.umd.js.map +1 -0
  4. package/bundles/lifeready-core.umd.min.js +16 -0
  5. package/bundles/lifeready-core.umd.min.js.map +1 -0
  6. package/esm2015/lib/_common/ast.js +40 -0
  7. package/esm2015/lib/_common/deferred-promise.js +24 -0
  8. package/esm2015/lib/_common/exceptions.js +157 -0
  9. package/esm2015/lib/_common/queries.gql.js +190 -0
  10. package/esm2015/lib/_common/run-outside-angular.js +79 -0
  11. package/esm2015/lib/_common/types.js +1 -0
  12. package/esm2015/lib/_common/utils.js +44 -0
  13. package/esm2015/lib/api/contact-card.gql.js +79 -0
  14. package/esm2015/lib/api/contact-card.service.js +154 -0
  15. package/esm2015/lib/api/contact-card2.gql.js +60 -0
  16. package/esm2015/lib/api/contact-card2.service.js +103 -0
  17. package/esm2015/lib/api/file.service.js +74 -0
  18. package/esm2015/lib/api/item2.gql.js +110 -0
  19. package/esm2015/lib/api/item2.service.js +311 -0
  20. package/esm2015/lib/api/key-exchange.gql.js +188 -0
  21. package/esm2015/lib/api/key-exchange.service.js +442 -0
  22. package/esm2015/lib/api/key-exchange.types.js +18 -0
  23. package/esm2015/lib/api/key-exchange2.gql.js +171 -0
  24. package/esm2015/lib/api/key-exchange2.service.js +479 -0
  25. package/esm2015/lib/api/lock.gql.js +40 -0
  26. package/esm2015/lib/api/lock.service.js +64 -0
  27. package/esm2015/lib/api/lr-apollo.service.js +46 -0
  28. package/esm2015/lib/api/lr-graphql/index.js +6 -0
  29. package/esm2015/lib/api/lr-graphql/lr-graphql.service.js +155 -0
  30. package/esm2015/lib/api/lr-graphql/lr-merged-mutation.js +213 -0
  31. package/esm2015/lib/api/lr-graphql/lr-mutation-base.js +51 -0
  32. package/esm2015/lib/api/lr-graphql/lr-mutation.js +48 -0
  33. package/esm2015/lib/api/lr-graphql/lr.service.js +18 -0
  34. package/esm2015/lib/api/message.service.js +138 -0
  35. package/esm2015/lib/api/persist.service.js +181 -0
  36. package/esm2015/lib/api/query-processor/common-processors.service.js +93 -0
  37. package/esm2015/lib/api/query-processor/index.js +3 -0
  38. package/esm2015/lib/api/query-processor/query-processor.service.js +192 -0
  39. package/esm2015/lib/api/query-processor/tp-password-reset-processor.service.js +109 -0
  40. package/esm2015/lib/api/shared-contact-card.service.js +119 -0
  41. package/esm2015/lib/api/shared-contact-card2.gql.js +41 -0
  42. package/esm2015/lib/api/shared-contact-card2.service.js +117 -0
  43. package/esm2015/lib/api/time.service.js +146 -0
  44. package/esm2015/lib/api/types/graphql.types.js +7 -0
  45. package/esm2015/lib/api/types/index.js +3 -0
  46. package/esm2015/lib/api/types/lr-graphql.types.js +71 -0
  47. package/esm2015/lib/auth/auth.config.js +57 -0
  48. package/esm2015/lib/auth/auth.gql.js +48 -0
  49. package/esm2015/lib/auth/auth.types.js +27 -0
  50. package/esm2015/lib/auth/idle.service.js +168 -0
  51. package/esm2015/lib/auth/idle.types.js +7 -0
  52. package/esm2015/lib/auth/lbop.service.js +355 -0
  53. package/esm2015/lib/auth/life-ready-auth.service.js +500 -0
  54. package/esm2015/lib/auth/password.service.js +320 -0
  55. package/esm2015/lib/auth/register.service.js +172 -0
  56. package/esm2015/lib/auth/two-factor.service.js +74 -0
  57. package/esm2015/lib/category/category-meta.service.js +99 -0
  58. package/esm2015/lib/category/category.gql.js +406 -0
  59. package/esm2015/lib/category/category.service.js +390 -0
  60. package/esm2015/lib/category/category.types.js +29 -0
  61. package/esm2015/lib/cryptography/cryptography.types.js +11 -0
  62. package/esm2015/lib/cryptography/encryption.service.js +189 -0
  63. package/esm2015/lib/cryptography/key-factory.service.js +237 -0
  64. package/esm2015/lib/cryptography/key-graph.service.js +280 -0
  65. package/esm2015/lib/cryptography/key-meta.service.js +200 -0
  66. package/esm2015/lib/cryptography/key.service.js +124 -0
  67. package/esm2015/lib/cryptography/slip39.service.js +169 -0
  68. package/esm2015/lib/cryptography/web-crypto.service.js +29 -0
  69. package/esm2015/lib/life-ready.config.js +84 -0
  70. package/esm2015/lib/life-ready.module.js +74 -0
  71. package/esm2015/lib/plan/plan.gql.js +123 -0
  72. package/esm2015/lib/plan/plan.service.js +149 -0
  73. package/esm2015/lib/plan/plan.types.js +11 -0
  74. package/esm2015/lib/record/record-attachment.service.js +101 -0
  75. package/esm2015/lib/record/record.gql.js +179 -0
  76. package/esm2015/lib/record/record.service.js +206 -0
  77. package/esm2015/lib/record/record.types.js +15 -0
  78. package/esm2015/lib/record-type/record-type.service.js +75 -0
  79. package/esm2015/lib/record-type/record-type.types.js +28 -0
  80. package/esm2015/lib/scenario/approvals/scenario-approval.gql.js +105 -0
  81. package/esm2015/lib/scenario/approvals/scenario-approval.types.js +1 -0
  82. package/esm2015/lib/scenario/approvals/scenario-approver.service.js +300 -0
  83. package/esm2015/lib/scenario/claimants/scenario-claimant.gql.js +52 -0
  84. package/esm2015/lib/scenario/claimants/scenario-claimant.service.js +97 -0
  85. package/esm2015/lib/scenario/claimants/scenario-claimant.types.js +1 -0
  86. package/esm2015/lib/scenario/receivers/scenario-receiver.gql.js +150 -0
  87. package/esm2015/lib/scenario/receivers/scenario-receiver.service.js +229 -0
  88. package/esm2015/lib/scenario/receivers/scenario-receiver.types.js +1 -0
  89. package/esm2015/lib/scenario/scenario-setup.service.js +269 -0
  90. package/esm2015/lib/scenario/scenario.gql.js +368 -0
  91. package/esm2015/lib/scenario/scenario.service.js +611 -0
  92. package/esm2015/lib/scenario/scenario.types.js +64 -0
  93. package/esm2015/lib/search/search.gql.js +62 -0
  94. package/esm2015/lib/search/search.service.js +156 -0
  95. package/esm2015/lib/search/search.types.js +6 -0
  96. package/esm2015/lib/trusted-parties/tp-password-reset-request.service.js +112 -0
  97. package/esm2015/lib/trusted-parties/tp-password-reset-user.service.js +129 -0
  98. package/esm2015/lib/trusted-parties/tp-password-reset.constants.js +4 -0
  99. package/esm2015/lib/trusted-parties/tp-password-reset.gql.js +232 -0
  100. package/esm2015/lib/trusted-parties/tp-password-reset.service.js +299 -0
  101. package/esm2015/lib/trusted-parties/trusted-party.gql.js +148 -0
  102. package/esm2015/lib/trusted-parties/trusted-party.service.js +326 -0
  103. package/esm2015/lib/trusted-parties/trusted-party.types.js +41 -0
  104. package/esm2015/lib/trusted-parties/trusted-party2.gql.js +87 -0
  105. package/esm2015/lib/trusted-parties/trusted-party2.service.js +215 -0
  106. package/esm2015/lib/users/profile-details.service.js +214 -0
  107. package/esm2015/lib/users/profile.gql.js +97 -0
  108. package/esm2015/lib/users/profile.service.js +169 -0
  109. package/esm2015/lib/users/profile.types.js +34 -0
  110. package/esm2015/lib/users/user.gql.js +60 -0
  111. package/esm2015/lib/users/user.service.js +79 -0
  112. package/esm2015/lib/users/user.types.js +5 -0
  113. package/esm2015/lifeready-core.js +10 -0
  114. package/esm2015/public-api.js +81 -0
  115. package/fesm2015/lifeready-core.js +13314 -0
  116. package/fesm2015/lifeready-core.js.map +1 -0
  117. package/lib/_common/ast.d.ts +11 -0
  118. package/lib/_common/deferred-promise.d.ts +12 -0
  119. package/lib/_common/exceptions.d.ts +109 -0
  120. package/lib/_common/queries.gql.d.ts +10 -0
  121. package/lib/_common/run-outside-angular.d.ts +14 -0
  122. package/{src/lib/_common/types.ts → lib/_common/types.d.ts} +10 -13
  123. package/lib/_common/utils.d.ts +3 -0
  124. package/lib/api/contact-card.gql.d.ts +7 -0
  125. package/lib/api/contact-card.service.d.ts +52 -0
  126. package/lib/api/contact-card2.gql.d.ts +34 -0
  127. package/lib/api/contact-card2.service.d.ts +49 -0
  128. package/lib/api/file.service.d.ts +18 -0
  129. package/lib/api/item2.gql.d.ts +96 -0
  130. package/lib/api/item2.service.d.ts +177 -0
  131. package/lib/api/key-exchange.gql.d.ts +9 -0
  132. package/lib/api/key-exchange.service.d.ts +39 -0
  133. package/lib/api/key-exchange.types.d.ts +196 -0
  134. package/lib/api/key-exchange2.gql.d.ts +125 -0
  135. package/lib/api/key-exchange2.service.d.ts +187 -0
  136. package/lib/api/lock.gql.d.ts +27 -0
  137. package/lib/api/lock.service.d.ts +25 -0
  138. package/lib/api/lr-apollo.service.d.ts +15 -0
  139. package/{src/lib/api/lr-graphql/index.ts → lib/api/lr-graphql/index.d.ts} +5 -5
  140. package/lib/api/lr-graphql/lr-graphql.service.d.ts +60 -0
  141. package/lib/api/lr-graphql/lr-merged-mutation.d.ts +27 -0
  142. package/lib/api/lr-graphql/lr-mutation-base.d.ts +28 -0
  143. package/lib/api/lr-graphql/lr-mutation.d.ts +8 -0
  144. package/lib/api/lr-graphql/lr.service.d.ts +9 -0
  145. package/lib/api/message.service.d.ts +58 -0
  146. package/lib/api/persist.service.d.ts +31 -0
  147. package/lib/api/query-processor/common-processors.service.d.ts +36 -0
  148. package/{src/lib/api/query-processor/index.ts → lib/api/query-processor/index.d.ts} +2 -2
  149. package/lib/api/query-processor/query-processor.service.d.ts +18 -0
  150. package/lib/api/query-processor/tp-password-reset-processor.service.d.ts +15 -0
  151. package/lib/api/shared-contact-card.service.d.ts +33 -0
  152. package/lib/api/shared-contact-card2.gql.d.ts +36 -0
  153. package/lib/api/shared-contact-card2.service.d.ts +45 -0
  154. package/lib/api/time.service.d.ts +16 -0
  155. package/lib/api/types/graphql.types.d.ts +29 -0
  156. package/{src/lib/api/types/index.ts → lib/api/types/index.d.ts} +2 -2
  157. package/lib/api/types/lr-graphql.types.d.ts +385 -0
  158. package/lib/auth/auth.config.d.ts +5 -0
  159. package/lib/auth/auth.gql.d.ts +15 -0
  160. package/lib/auth/auth.types.d.ts +66 -0
  161. package/lib/auth/idle.service.d.ts +40 -0
  162. package/lib/auth/idle.types.d.ts +10 -0
  163. package/lib/auth/lbop.service.d.ts +91 -0
  164. package/lib/auth/life-ready-auth.service.d.ts +59 -0
  165. package/lib/auth/password.service.d.ts +78 -0
  166. package/lib/auth/register.service.d.ts +25 -0
  167. package/lib/auth/two-factor.service.d.ts +15 -0
  168. package/lib/category/category-meta.service.d.ts +23 -0
  169. package/lib/category/category.gql.d.ts +45 -0
  170. package/lib/category/category.service.d.ts +67 -0
  171. package/lib/category/category.types.d.ts +79 -0
  172. package/lib/cryptography/cryptography.types.d.ts +83 -0
  173. package/lib/cryptography/encryption.service.d.ts +41 -0
  174. package/lib/cryptography/key-factory.service.d.ts +38 -0
  175. package/lib/cryptography/key-graph.service.d.ts +33 -0
  176. package/lib/cryptography/key-meta.service.d.ts +44 -0
  177. package/lib/cryptography/key.service.d.ts +36 -0
  178. package/lib/cryptography/slip39.service.d.ts +43 -0
  179. package/lib/cryptography/web-crypto.service.d.ts +5 -0
  180. package/lib/life-ready.config.d.ts +14 -0
  181. package/lib/life-ready.module.d.ts +5 -0
  182. package/lib/plan/plan.gql.d.ts +11 -0
  183. package/lib/plan/plan.service.d.ts +33 -0
  184. package/lib/plan/plan.types.d.ts +31 -0
  185. package/lib/record/record-attachment.service.d.ts +16 -0
  186. package/lib/record/record.gql.d.ts +14 -0
  187. package/lib/record/record.service.d.ts +25 -0
  188. package/lib/record/record.types.d.ts +57 -0
  189. package/lib/record-type/record-type.service.d.ts +11 -0
  190. package/lib/record-type/record-type.types.d.ts +50 -0
  191. package/lib/scenario/approvals/scenario-approval.gql.d.ts +7 -0
  192. package/lib/scenario/approvals/scenario-approval.types.d.ts +63 -0
  193. package/lib/scenario/approvals/scenario-approver.service.d.ts +32 -0
  194. package/lib/scenario/claimants/scenario-claimant.gql.d.ts +5 -0
  195. package/lib/scenario/claimants/scenario-claimant.service.d.ts +17 -0
  196. package/lib/scenario/claimants/scenario-claimant.types.d.ts +18 -0
  197. package/lib/scenario/receivers/scenario-receiver.gql.d.ts +8 -0
  198. package/lib/scenario/receivers/scenario-receiver.service.d.ts +30 -0
  199. package/lib/scenario/receivers/scenario-receiver.types.d.ts +54 -0
  200. package/lib/scenario/scenario-setup.service.d.ts +22 -0
  201. package/lib/scenario/scenario.gql.d.ts +34 -0
  202. package/lib/scenario/scenario.service.d.ts +58 -0
  203. package/lib/scenario/scenario.types.d.ts +217 -0
  204. package/lib/search/search.gql.d.ts +1 -0
  205. package/lib/search/search.service.d.ts +25 -0
  206. package/lib/search/search.types.d.ts +20 -0
  207. package/lib/trusted-parties/tp-password-reset-request.service.d.ts +20 -0
  208. package/lib/trusted-parties/tp-password-reset-user.service.d.ts +35 -0
  209. package/lib/trusted-parties/tp-password-reset.constants.d.ts +3 -0
  210. package/lib/trusted-parties/tp-password-reset.gql.d.ts +218 -0
  211. package/lib/trusted-parties/tp-password-reset.service.d.ts +130 -0
  212. package/lib/trusted-parties/trusted-party.gql.d.ts +9 -0
  213. package/lib/trusted-parties/trusted-party.service.d.ts +44 -0
  214. package/lib/trusted-parties/trusted-party.types.d.ts +102 -0
  215. package/lib/trusted-parties/trusted-party2.gql.d.ts +79 -0
  216. package/lib/trusted-parties/trusted-party2.service.d.ts +114 -0
  217. package/lib/users/profile-details.service.d.ts +21 -0
  218. package/lib/users/profile.gql.d.ts +11 -0
  219. package/lib/users/profile.service.d.ts +35 -0
  220. package/lib/users/profile.types.d.ts +96 -0
  221. package/lib/users/user.gql.d.ts +9 -0
  222. package/lib/users/user.service.d.ts +12 -0
  223. package/lib/users/user.types.d.ts +23 -0
  224. package/lifeready-core.d.ts +9 -0
  225. package/lifeready-core.metadata.json +1 -0
  226. package/package.json +29 -21
  227. package/{src/public-api.ts → public-api.d.ts} +77 -96
  228. package/karma.conf.js +0 -32
  229. package/ng-package.json +0 -26
  230. package/src/lib/_common/ast.ts +0 -75
  231. package/src/lib/_common/deferred-promise.ts +0 -35
  232. package/src/lib/_common/exceptions.ts +0 -189
  233. package/src/lib/_common/queries.gql.ts +0 -200
  234. package/src/lib/_common/run-outside-angular.ts +0 -125
  235. package/src/lib/_common/tests.ts +0 -82
  236. package/src/lib/_common/utils.ts +0 -57
  237. package/src/lib/api/api-mutation.spec.ts +0 -547
  238. package/src/lib/api/api-query.spec.ts +0 -40
  239. package/src/lib/api/contact-card.gql.ts +0 -85
  240. package/src/lib/api/contact-card.service.spec.ts +0 -249
  241. package/src/lib/api/contact-card.service.ts +0 -228
  242. package/src/lib/api/contact-card2.gql.ts +0 -93
  243. package/src/lib/api/contact-card2.service.spec.ts +0 -297
  244. package/src/lib/api/contact-card2.service.ts +0 -139
  245. package/src/lib/api/file.service.spec.ts +0 -14
  246. package/src/lib/api/file.service.ts +0 -81
  247. package/src/lib/api/item2.gql.ts +0 -211
  248. package/src/lib/api/item2.service.spec.ts +0 -1043
  249. package/src/lib/api/item2.service.ts +0 -481
  250. package/src/lib/api/key-exchange.gql.ts +0 -196
  251. package/src/lib/api/key-exchange.service.spec.ts +0 -470
  252. package/src/lib/api/key-exchange.service.ts +0 -731
  253. package/src/lib/api/key-exchange.types.ts +0 -235
  254. package/src/lib/api/key-exchange2.gql.ts +0 -310
  255. package/src/lib/api/key-exchange2.service.spec.ts +0 -892
  256. package/src/lib/api/key-exchange2.service.ts +0 -875
  257. package/src/lib/api/lock.gql.ts +0 -67
  258. package/src/lib/api/lock.service.spec.ts +0 -549
  259. package/src/lib/api/lock.service.ts +0 -57
  260. package/src/lib/api/lr-apollo.service.spec.ts +0 -27
  261. package/src/lib/api/lr-apollo.service.ts +0 -43
  262. package/src/lib/api/lr-graphql/lr-graphql.service.ts +0 -313
  263. package/src/lib/api/lr-graphql/lr-merged-mutation.ts +0 -377
  264. package/src/lib/api/lr-graphql/lr-mutation-base.ts +0 -67
  265. package/src/lib/api/lr-graphql/lr-mutation.ts +0 -74
  266. package/src/lib/api/lr-graphql/lr.service.ts +0 -28
  267. package/src/lib/api/message.service.spec.ts +0 -20
  268. package/src/lib/api/message.service.ts +0 -210
  269. package/src/lib/api/persist.service.spec.ts +0 -209
  270. package/src/lib/api/persist.service.ts +0 -220
  271. package/src/lib/api/query-processor/common-processors.service.ts +0 -148
  272. package/src/lib/api/query-processor/query-processor.service.ts +0 -240
  273. package/src/lib/api/query-processor/tp-password-reset-processor.service.ts +0 -177
  274. package/src/lib/api/shared-contact-card.service.ts +0 -156
  275. package/src/lib/api/shared-contact-card2.gql.ts +0 -76
  276. package/src/lib/api/shared-contact-card2.service.ts +0 -154
  277. package/src/lib/api/time.service.spec.ts +0 -48
  278. package/src/lib/api/time.service.ts +0 -155
  279. package/src/lib/api/types/graphql.types.ts +0 -48
  280. package/src/lib/api/types/lr-graphql.types.ts +0 -467
  281. package/src/lib/auth/auth.config.ts +0 -83
  282. package/src/lib/auth/auth.gql.ts +0 -62
  283. package/src/lib/auth/auth.types.ts +0 -79
  284. package/src/lib/auth/idle.service.spec.ts +0 -119
  285. package/src/lib/auth/idle.service.ts +0 -208
  286. package/src/lib/auth/idle.types.ts +0 -11
  287. package/src/lib/auth/lbop.service.spec.ts +0 -56
  288. package/src/lib/auth/lbop.service.ts +0 -539
  289. package/src/lib/auth/life-ready-auth.service.spec.ts +0 -70
  290. package/src/lib/auth/life-ready-auth.service.ts +0 -454
  291. package/src/lib/auth/password.service.spec.ts +0 -51
  292. package/src/lib/auth/password.service.ts +0 -438
  293. package/src/lib/auth/register.service.spec.ts +0 -31
  294. package/src/lib/auth/register.service.ts +0 -181
  295. package/src/lib/auth/two-factor.service.spec.ts +0 -21
  296. package/src/lib/auth/two-factor.service.ts +0 -69
  297. package/src/lib/category/category-meta.service.spec.ts +0 -28
  298. package/src/lib/category/category-meta.service.ts +0 -125
  299. package/src/lib/category/category.gql.ts +0 -449
  300. package/src/lib/category/category.service.spec.ts +0 -26
  301. package/src/lib/category/category.service.ts +0 -498
  302. package/src/lib/category/category.types.ts +0 -89
  303. package/src/lib/cryptography/cryptography.types.ts +0 -108
  304. package/src/lib/cryptography/encryption.service.spec.ts +0 -125
  305. package/src/lib/cryptography/encryption.service.ts +0 -243
  306. package/src/lib/cryptography/key-factory.service.spec.ts +0 -15
  307. package/src/lib/cryptography/key-factory.service.ts +0 -303
  308. package/src/lib/cryptography/key-graph.service.spec.ts +0 -16
  309. package/src/lib/cryptography/key-graph.service.ts +0 -354
  310. package/src/lib/cryptography/key-meta.service.spec.ts +0 -40
  311. package/src/lib/cryptography/key-meta.service.ts +0 -254
  312. package/src/lib/cryptography/key.service.spec.ts +0 -16
  313. package/src/lib/cryptography/key.service.ts +0 -154
  314. package/src/lib/cryptography/slip39.service.spec.ts +0 -44
  315. package/src/lib/cryptography/slip39.service.ts +0 -204
  316. package/src/lib/cryptography/web-crypto.service.ts +0 -22
  317. package/src/lib/life-ready.config.ts +0 -127
  318. package/src/lib/life-ready.module.ts +0 -81
  319. package/src/lib/plan/plan.gql.ts +0 -133
  320. package/src/lib/plan/plan.service.spec.ts +0 -294
  321. package/src/lib/plan/plan.service.ts +0 -198
  322. package/src/lib/plan/plan.types.ts +0 -37
  323. package/src/lib/record/record-attachment.service.spec.ts +0 -31
  324. package/src/lib/record/record-attachment.service.ts +0 -101
  325. package/src/lib/record/record.gql.ts +0 -192
  326. package/src/lib/record/record.service.spec.ts +0 -598
  327. package/src/lib/record/record.service.ts +0 -236
  328. package/src/lib/record/record.types.ts +0 -86
  329. package/src/lib/record-type/record-type.service.spec.ts +0 -16
  330. package/src/lib/record-type/record-type.service.ts +0 -71
  331. package/src/lib/record-type/record-type.types.ts +0 -58
  332. package/src/lib/scenario/approvals/scenario-approval.gql.ts +0 -112
  333. package/src/lib/scenario/approvals/scenario-approval.types.ts +0 -85
  334. package/src/lib/scenario/approvals/scenario-approver.service.spec.ts +0 -16
  335. package/src/lib/scenario/approvals/scenario-approver.service.ts +0 -422
  336. package/src/lib/scenario/claimants/scenario-claimant.gql.ts +0 -56
  337. package/src/lib/scenario/claimants/scenario-claimant.service.spec.ts +0 -16
  338. package/src/lib/scenario/claimants/scenario-claimant.service.ts +0 -100
  339. package/src/lib/scenario/claimants/scenario-claimant.types.ts +0 -21
  340. package/src/lib/scenario/receivers/scenario-receiver.gql.ts +0 -157
  341. package/src/lib/scenario/receivers/scenario-receiver.service.spec.ts +0 -16
  342. package/src/lib/scenario/receivers/scenario-receiver.service.ts +0 -278
  343. package/src/lib/scenario/receivers/scenario-receiver.types.ts +0 -66
  344. package/src/lib/scenario/scenario-setup.service.spec.ts +0 -22
  345. package/src/lib/scenario/scenario-setup.service.ts +0 -369
  346. package/src/lib/scenario/scenario.gql.ts +0 -404
  347. package/src/lib/scenario/scenario.service.spec.ts +0 -1586
  348. package/src/lib/scenario/scenario.service.ts +0 -811
  349. package/src/lib/scenario/scenario.types.ts +0 -258
  350. package/src/lib/search/search.gql.ts +0 -62
  351. package/src/lib/search/search.service.spec.ts +0 -57
  352. package/src/lib/search/search.service.ts +0 -174
  353. package/src/lib/search/search.types.ts +0 -24
  354. package/src/lib/trusted-parties/tp-password-reset-request.service.ts +0 -140
  355. package/src/lib/trusted-parties/tp-password-reset-user.service.ts +0 -359
  356. package/src/lib/trusted-parties/tp-password-reset.gql.ts +0 -453
  357. package/src/lib/trusted-parties/tp-password-reset.service.spec.ts +0 -602
  358. package/src/lib/trusted-parties/tp-password-reset.service.ts +0 -482
  359. package/src/lib/trusted-parties/trusted-party.gql.ts +0 -159
  360. package/src/lib/trusted-parties/trusted-party.service.spec.ts +0 -1008
  361. package/src/lib/trusted-parties/trusted-party.service.ts +0 -394
  362. package/src/lib/trusted-parties/trusted-party.types.ts +0 -119
  363. package/src/lib/trusted-parties/trusted-party2.gql.ts +0 -165
  364. package/src/lib/trusted-parties/trusted-party2.service.spec.ts +0 -1782
  365. package/src/lib/trusted-parties/trusted-party2.service.ts +0 -272
  366. package/src/lib/users/profile-details.service.spec.ts +0 -45
  367. package/src/lib/users/profile-details.service.ts +0 -278
  368. package/src/lib/users/profile.gql.ts +0 -108
  369. package/src/lib/users/profile.service.spec.ts +0 -97
  370. package/src/lib/users/profile.service.ts +0 -224
  371. package/src/lib/users/profile.types.ts +0 -101
  372. package/src/lib/users/user.gql.ts +0 -69
  373. package/src/lib/users/user.service.spec.ts +0 -161
  374. package/src/lib/users/user.service.ts +0 -72
  375. package/src/lib/users/user.types.ts +0 -27
  376. package/src/test.ts +0 -21
  377. package/tsconfig.lib.json +0 -21
  378. package/tsconfig.lib.prod.json +0 -6
  379. package/tsconfig.spec.json +0 -10
  380. package/tslint.json +0 -17
@@ -0,0 +1,40 @@
1
+ // Abstract Syntax Tree
2
+ import gql from 'graphql-tag';
3
+ import { LrBadArgumentException, LrBadLogicException } from './exceptions';
4
+ export function getAstOperation(astDocument, operation) {
5
+ const operations = astDocument.definitions.filter((def) => def.kind === 'OperationDefinition');
6
+ if (operations.length > 1) {
7
+ throw new LrBadLogicException(`There can be only one '${operation}' operation, instead there are ${operations.length}`);
8
+ }
9
+ return operations[0];
10
+ }
11
+ export function getQuery(doc) {
12
+ return getAstOperation(doc, 'query');
13
+ }
14
+ export function getMutation(doc) {
15
+ return getAstOperation(doc, 'mutation');
16
+ }
17
+ export function getFragments(doc) {
18
+ return doc.definitions.filter((def) => def.kind === 'FragmentDefinition');
19
+ }
20
+ export function getFragment(astDocument) {
21
+ const fragments = getFragments(astDocument);
22
+ if (fragments.length > 1) {
23
+ throw new LrBadArgumentException('GraphQL document can only contain one fragment.');
24
+ }
25
+ return fragments[0];
26
+ }
27
+ export function name(value) {
28
+ return {
29
+ kind: 'Name',
30
+ value,
31
+ };
32
+ }
33
+ export function getAliasOrName(field) {
34
+ var _a;
35
+ return ((_a = field.alias) === null || _a === void 0 ? void 0 : _a.value) || field.name.value;
36
+ }
37
+ export function gqlTyped(literals, ...placeholders) {
38
+ return gql(literals, ...placeholders);
39
+ }
40
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXN0LmpzIiwic291cmNlUm9vdCI6Ii9vcHQvYXRsYXNzaWFuL3BpcGVsaW5lcy9hZ2VudC9idWlsZC9wcm9qZWN0cy9jb3JlL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9fY29tbW9uL2FzdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSx1QkFBdUI7QUFVdkIsT0FBTyxHQUFHLE1BQU0sYUFBYSxDQUFDO0FBQzlCLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUUzRSxNQUFNLFVBQVUsZUFBZSxDQUM3QixXQUFXLEVBQ1gsU0FBNEI7SUFFNUIsTUFBTSxVQUFVLEdBQUcsV0FBVyxDQUFDLFdBQVcsQ0FBQyxNQUFNLENBQy9DLENBQUMsR0FBNEIsRUFBRSxFQUFFLENBQUMsR0FBRyxDQUFDLElBQUksS0FBSyxxQkFBcUIsQ0FDckUsQ0FBQztJQUVGLElBQUksVUFBVSxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUU7UUFDekIsTUFBTSxJQUFJLG1CQUFtQixDQUMzQiwwQkFBMEIsU0FBUyxrQ0FBa0MsVUFBVSxDQUFDLE1BQU0sRUFBRSxDQUN6RixDQUFDO0tBQ0g7SUFFRCxPQUFPLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUN2QixDQUFDO0FBRUQsTUFBTSxVQUFVLFFBQVEsQ0FBQyxHQUFpQjtJQUN4QyxPQUFPLGVBQWUsQ0FBQyxHQUFHLEVBQUUsT0FBTyxDQUFDLENBQUM7QUFDdkMsQ0FBQztBQUVELE1BQU0sVUFBVSxXQUFXLENBQUMsR0FBaUI7SUFDM0MsT0FBTyxlQUFlLENBQUMsR0FBRyxFQUFFLFVBQVUsQ0FBQyxDQUFDO0FBQzFDLENBQUM7QUFFRCxNQUFNLFVBQVUsWUFBWSxDQUFDLEdBQWlCO0lBQzVDLE9BQU8sR0FBRyxDQUFDLFdBQVcsQ0FBQyxNQUFNLENBQzNCLENBQUMsR0FBRyxFQUFFLEVBQUUsQ0FBQyxHQUFHLENBQUMsSUFBSSxLQUFLLG9CQUFvQixDQUNmLENBQUM7QUFDaEMsQ0FBQztBQUVELE1BQU0sVUFBVSxXQUFXLENBQUMsV0FBeUI7SUFDbkQsTUFBTSxTQUFTLEdBQUcsWUFBWSxDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBQzVDLElBQUksU0FBUyxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUU7UUFDeEIsTUFBTSxJQUFJLHNCQUFzQixDQUM5QixpREFBaUQsQ0FDbEQsQ0FBQztLQUNIO0lBQ0QsT0FBTyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFDdEIsQ0FBQztBQUVELE1BQU0sVUFBVSxJQUFJLENBQUMsS0FBYTtJQUNoQyxPQUFPO1FBQ0wsSUFBSSxFQUFFLE1BQU07UUFDWixLQUFLO0tBQ04sQ0FBQztBQUNKLENBQUM7QUFFRCxNQUFNLFVBQVUsY0FBYyxDQUFDLEtBQWdCOztJQUM3QyxPQUFPLE9BQUEsS0FBSyxDQUFDLEtBQUssMENBQUUsS0FBSyxLQUFJLEtBQUssQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDO0FBQ2hELENBQUM7QUFNRCxNQUFNLFVBQVUsUUFBUSxDQUN0QixRQUFrRCxFQUNsRCxHQUFHLFlBQW1CO0lBRXRCLE9BQU8sR0FBRyxDQUFDLFFBQVEsRUFBRSxHQUFHLFlBQVksQ0FBeUIsQ0FBQztBQUNoRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQWJzdHJhY3QgU3ludGF4IFRyZWVcblxuaW1wb3J0IHtcbiAgRG9jdW1lbnROb2RlLFxuICBGaWVsZE5vZGUsXG4gIEZyYWdtZW50RGVmaW5pdGlvbk5vZGUsXG4gIE5hbWVOb2RlLFxuICBPcGVyYXRpb25EZWZpbml0aW9uTm9kZSxcbiAgT3BlcmF0aW9uVHlwZU5vZGUsXG59IGZyb20gJ2dyYXBocWwnO1xuaW1wb3J0IGdxbCBmcm9tICdncmFwaHFsLXRhZyc7XG5pbXBvcnQgeyBMckJhZEFyZ3VtZW50RXhjZXB0aW9uLCBMckJhZExvZ2ljRXhjZXB0aW9uIH0gZnJvbSAnLi9leGNlcHRpb25zJztcblxuZXhwb3J0IGZ1bmN0aW9uIGdldEFzdE9wZXJhdGlvbihcbiAgYXN0RG9jdW1lbnQsXG4gIG9wZXJhdGlvbjogT3BlcmF0aW9uVHlwZU5vZGVcbik6IE9wZXJhdGlvbkRlZmluaXRpb25Ob2RlIHtcbiAgY29uc3Qgb3BlcmF0aW9ucyA9IGFzdERvY3VtZW50LmRlZmluaXRpb25zLmZpbHRlcihcbiAgICAoZGVmOiBPcGVyYXRpb25EZWZpbml0aW9uTm9kZSkgPT4gZGVmLmtpbmQgPT09ICdPcGVyYXRpb25EZWZpbml0aW9uJ1xuICApO1xuXG4gIGlmIChvcGVyYXRpb25zLmxlbmd0aCA+IDEpIHtcbiAgICB0aHJvdyBuZXcgTHJCYWRMb2dpY0V4Y2VwdGlvbihcbiAgICAgIGBUaGVyZSBjYW4gYmUgb25seSBvbmUgJyR7b3BlcmF0aW9ufScgb3BlcmF0aW9uLCBpbnN0ZWFkIHRoZXJlIGFyZSAke29wZXJhdGlvbnMubGVuZ3RofWBcbiAgICApO1xuICB9XG5cbiAgcmV0dXJuIG9wZXJhdGlvbnNbMF07XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRRdWVyeShkb2M6IERvY3VtZW50Tm9kZSk6IE9wZXJhdGlvbkRlZmluaXRpb25Ob2RlIHtcbiAgcmV0dXJuIGdldEFzdE9wZXJhdGlvbihkb2MsICdxdWVyeScpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0TXV0YXRpb24oZG9jOiBEb2N1bWVudE5vZGUpOiBPcGVyYXRpb25EZWZpbml0aW9uTm9kZSB7XG4gIHJldHVybiBnZXRBc3RPcGVyYXRpb24oZG9jLCAnbXV0YXRpb24nKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldEZyYWdtZW50cyhkb2M6IERvY3VtZW50Tm9kZSk6IEZyYWdtZW50RGVmaW5pdGlvbk5vZGVbXSB7XG4gIHJldHVybiBkb2MuZGVmaW5pdGlvbnMuZmlsdGVyKFxuICAgIChkZWYpID0+IGRlZi5raW5kID09PSAnRnJhZ21lbnREZWZpbml0aW9uJ1xuICApIGFzIEZyYWdtZW50RGVmaW5pdGlvbk5vZGVbXTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldEZyYWdtZW50KGFzdERvY3VtZW50OiBEb2N1bWVudE5vZGUpOiBGcmFnbWVudERlZmluaXRpb25Ob2RlIHtcbiAgY29uc3QgZnJhZ21lbnRzID0gZ2V0RnJhZ21lbnRzKGFzdERvY3VtZW50KTtcbiAgaWYgKGZyYWdtZW50cy5sZW5ndGggPiAxKSB7XG4gICAgdGhyb3cgbmV3IExyQmFkQXJndW1lbnRFeGNlcHRpb24oXG4gICAgICAnR3JhcGhRTCBkb2N1bWVudCBjYW4gb25seSBjb250YWluIG9uZSBmcmFnbWVudC4nXG4gICAgKTtcbiAgfVxuICByZXR1cm4gZnJhZ21lbnRzWzBdO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gbmFtZSh2YWx1ZTogc3RyaW5nKTogTmFtZU5vZGUge1xuICByZXR1cm4ge1xuICAgIGtpbmQ6ICdOYW1lJyxcbiAgICB2YWx1ZSxcbiAgfTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldEFsaWFzT3JOYW1lKGZpZWxkOiBGaWVsZE5vZGUpIHtcbiAgcmV0dXJuIGZpZWxkLmFsaWFzPy52YWx1ZSB8fCBmaWVsZC5uYW1lLnZhbHVlO1xufVxuXG4vLyBDb2xsb2NhdGVzIHRoZSB0eXBlIHdpdGggdGhlIGRvY3VtZW50LlxuLyogdHNsaW50OmRpc2FibGU6bm8tZW1wdHktaW50ZXJmYWNlICovXG5leHBvcnQgaW50ZXJmYWNlIFR5cGVkRG9jdW1lbnROb2RlPFQ+IGV4dGVuZHMgRG9jdW1lbnROb2RlIHt9XG5cbmV4cG9ydCBmdW5jdGlvbiBncWxUeXBlZDxUID0gYW55PihcbiAgbGl0ZXJhbHM6IFJlYWRvbmx5QXJyYXk8c3RyaW5nPiB8IFJlYWRvbmx5PHN0cmluZz4sXG4gIC4uLnBsYWNlaG9sZGVyczogYW55W11cbik6IFR5cGVkRG9jdW1lbnROb2RlPFQ+IHtcbiAgcmV0dXJuIGdxbChsaXRlcmFscywgLi4ucGxhY2Vob2xkZXJzKSBhcyBUeXBlZERvY3VtZW50Tm9kZTxUPjtcbn1cbiJdfQ==
@@ -0,0 +1,24 @@
1
+ export class DeferredPromise {
2
+ constructor() {
3
+ /* tslint:disable: variable-name */
4
+ this._fulfilled = false;
5
+ this.promise = new Promise((resolve, reject) => {
6
+ this._resolve = resolve;
7
+ this._reject = reject;
8
+ }).finally(() => {
9
+ // finally() simply gets called on both then() and catch(). The promise
10
+ // chain continues on.
11
+ this._fulfilled = true;
12
+ });
13
+ }
14
+ get resolve() {
15
+ return this._resolve;
16
+ }
17
+ get reject() {
18
+ return this._reject;
19
+ }
20
+ get fulfilled() {
21
+ return this._fulfilled;
22
+ }
23
+ }
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVmZXJyZWQtcHJvbWlzZS5qcyIsInNvdXJjZVJvb3QiOiIvb3B0L2F0bGFzc2lhbi9waXBlbGluZXMvYWdlbnQvYnVpbGQvcHJvamVjdHMvY29yZS9zcmMvIiwic291cmNlcyI6WyJsaWIvX2NvbW1vbi9kZWZlcnJlZC1wcm9taXNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUdBLE1BQU0sT0FBTyxlQUFlO0lBUzFCO1FBSEEsbUNBQW1DO1FBQzNCLGVBQVUsR0FBRyxLQUFLLENBQUM7UUFHekIsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLE9BQU8sQ0FBSSxDQUFDLE9BQU8sRUFBRSxNQUFNLEVBQUUsRUFBRTtZQUNoRCxJQUFJLENBQUMsUUFBUSxHQUFHLE9BQU8sQ0FBQztZQUN4QixJQUFJLENBQUMsT0FBTyxHQUFHLE1BQU0sQ0FBQztRQUN4QixDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsR0FBRyxFQUFFO1lBQ2QsdUVBQXVFO1lBQ3ZFLHNCQUFzQjtZQUN0QixJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQztRQUN6QixDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxJQUFJLE9BQU87UUFDVCxPQUFPLElBQUksQ0FBQyxRQUFRLENBQUM7SUFDdkIsQ0FBQztJQUVELElBQUksTUFBTTtRQUNSLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQztJQUN0QixDQUFDO0lBRUQsSUFBSSxTQUFTO1FBQ1gsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDO0lBQ3pCLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB0eXBlIFJlc29sdmVQcm9taXNlPFQ+ID0gKHZhbHVlPzogVCB8IFByb21pc2VMaWtlPFQ+KSA9PiB2b2lkO1xuZXhwb3J0IHR5cGUgUmVqZWN0UHJvbWlzZSA9IChyZWFzb24/OiBhbnkpID0+IHZvaWQ7XG5cbmV4cG9ydCBjbGFzcyBEZWZlcnJlZFByb21pc2U8VD4ge1xuICBwdWJsaWMgcmVhZG9ubHkgcHJvbWlzZTogUHJvbWlzZTxUPjtcbiAgLyogdHNsaW50OmRpc2FibGU6IHZhcmlhYmxlLW5hbWUgKi9cbiAgcHJpdmF0ZSBfcmVzb2x2ZTogUmVzb2x2ZVByb21pc2U8VD47XG4gIC8qIHRzbGludDpkaXNhYmxlOiB2YXJpYWJsZS1uYW1lICovXG4gIHByaXZhdGUgX3JlamVjdDogUmVqZWN0UHJvbWlzZTtcbiAgLyogdHNsaW50OmRpc2FibGU6IHZhcmlhYmxlLW5hbWUgKi9cbiAgcHJpdmF0ZSBfZnVsZmlsbGVkID0gZmFsc2U7XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gICAgdGhpcy5wcm9taXNlID0gbmV3IFByb21pc2U8VD4oKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgICAgdGhpcy5fcmVzb2x2ZSA9IHJlc29sdmU7XG4gICAgICB0aGlzLl9yZWplY3QgPSByZWplY3Q7XG4gICAgfSkuZmluYWxseSgoKSA9PiB7XG4gICAgICAvLyBmaW5hbGx5KCkgc2ltcGx5IGdldHMgY2FsbGVkIG9uIGJvdGggdGhlbigpIGFuZCBjYXRjaCgpLiBUaGUgcHJvbWlzZVxuICAgICAgLy8gY2hhaW4gY29udGludWVzIG9uLlxuICAgICAgdGhpcy5fZnVsZmlsbGVkID0gdHJ1ZTtcbiAgICB9KTtcbiAgfVxuXG4gIGdldCByZXNvbHZlKCkge1xuICAgIHJldHVybiB0aGlzLl9yZXNvbHZlO1xuICB9XG5cbiAgZ2V0IHJlamVjdCgpIHtcbiAgICByZXR1cm4gdGhpcy5fcmVqZWN0O1xuICB9XG5cbiAgZ2V0IGZ1bGZpbGxlZCgpIHtcbiAgICByZXR1cm4gdGhpcy5fZnVsZmlsbGVkO1xuICB9XG59XG4iXX0=
@@ -0,0 +1,157 @@
1
+ export function handleApolloError(errors) {
2
+ if (!errors || !errors.length)
3
+ return;
4
+ const lrErrors = errors.map((x) => ({
5
+ code: x.extensions && x.extensions.code,
6
+ source: x.extensions && x.extensions.source,
7
+ message: x.message,
8
+ debug: {
9
+ locations: x.locations,
10
+ path: x.path,
11
+ },
12
+ }));
13
+ throw new LrException(...lrErrors);
14
+ }
15
+ export class LrError {
16
+ }
17
+ export class LrException {
18
+ constructor(...errors) {
19
+ this.errors = errors;
20
+ }
21
+ toString() {
22
+ return this.errors.map((t) => JSON.stringify(t, null, 2));
23
+ }
24
+ }
25
+ export var LrApiErrorCode;
26
+ (function (LrApiErrorCode) {
27
+ LrApiErrorCode["ARCHIVED_RESOURCE"] = "ARCHIVED_RESOURCE";
28
+ LrApiErrorCode["BAD_ARGUMENT"] = "BAD_ARGUMENT";
29
+ LrApiErrorCode["BAD_SIGNATURE"] = "BAD_SIGNATURE";
30
+ LrApiErrorCode["BAD_STATE"] = "BAD_STATE";
31
+ LrApiErrorCode["CHANGED_PERMISSIONS"] = "CHANGED_PERMISSIONS";
32
+ LrApiErrorCode["CONCURRENT_ACCESS"] = "CONCURRENT_ACCESS";
33
+ LrApiErrorCode["CONFIG_ERROR"] = "CONFIG_ERROR";
34
+ LrApiErrorCode["CYCLE_DETECTED"] = "CYCLE_DETECTED";
35
+ LrApiErrorCode["EXPIRED"] = "EXPIRED";
36
+ LrApiErrorCode["INVALID_TOKEN"] = "INVALID_TOKEN";
37
+ LrApiErrorCode["INTERNAL_ERROR"] = "INTERNAL_ERROR";
38
+ LrApiErrorCode["JSON_DECODE_ERROR"] = "JSON_DECODE_ERROR";
39
+ LrApiErrorCode["KEY_MISMATCH"] = "KEY_MISMATCH";
40
+ LrApiErrorCode["LIMIT_REACHED"] = "LIMIT_REACHED";
41
+ LrApiErrorCode["LOCKED"] = "LOCKED";
42
+ LrApiErrorCode["LOGIC_ERROR"] = "LOGIC_ERROR";
43
+ LrApiErrorCode["LR_DEBUG_ONLY"] = "LR_DEBUG_ONLY";
44
+ LrApiErrorCode["MIN_DELAY"] = "MIN_DELAY";
45
+ LrApiErrorCode["MISSING_FIELD"] = "MISSING_FIELD";
46
+ LrApiErrorCode["MISSING_FIELD_VALUE"] = "MISSING_FIELD_VALUE";
47
+ LrApiErrorCode["MISSING_QUERY_PARAM"] = "MISSING_QUERY_PARAM";
48
+ LrApiErrorCode["NOT_IMPLEMENTED"] = "NOT_IMPLEMENTED";
49
+ LrApiErrorCode["OBJECT_DOES_NOT_EXIST"] = "OBJECT_DOES_NOT_EXIST";
50
+ LrApiErrorCode["OBJECT_EXISTS"] = "OBJECT_EXISTS";
51
+ LrApiErrorCode["RANGE_ERROR"] = "RANGE_ERROR";
52
+ LrApiErrorCode["TRUSTED_PARTY_NOT_FOUND"] = "TRUSTED_PARTY_NOT_FOUND";
53
+ LrApiErrorCode["UNAUTHENTICATED_USER"] = "UNAUTHENTICATED_USER";
54
+ LrApiErrorCode["USER_NOT_FOUND"] = "USER_NOT_FOUND";
55
+ LrApiErrorCode["VERSION_MISMATCH"] = "VERSION_MISMATCH";
56
+ LrApiErrorCode["WRONG_PERMISSIONS"] = "WRONG_PERMISSIONS";
57
+ })(LrApiErrorCode || (LrApiErrorCode = {}));
58
+ export var LrErrorCode;
59
+ (function (LrErrorCode) {
60
+ LrErrorCode["BadTimeSync"] = "LrBadTimeSync";
61
+ LrErrorCode["ReceiveClaimMismatch"] = "LrReceiveClaimMismatch";
62
+ LrErrorCode["BadState"] = "LrBadState";
63
+ LrErrorCode["BadSignature"] = "LrBadSignature";
64
+ LrErrorCode["Auth"] = "LrAuth";
65
+ LrErrorCode["BadArgument"] = "LrBadArgument";
66
+ LrErrorCode["SuspiciousException"] = "LrSuspiciousException";
67
+ LrErrorCode["NotFound"] = "LrNotFound";
68
+ LrErrorCode["BadLogic"] = "LrBadLogicException";
69
+ LrErrorCode["CodeMismatch"] = "LrCodeMismatchException";
70
+ LrErrorCode["ConcurrentAccess"] = "LrConcurrentAccessException";
71
+ LrErrorCode["BadRequest"] = "LrBadRequestException";
72
+ LrErrorCode["Encryption"] = "LrEncryptionGoBad";
73
+ LrErrorCode["Locked"] = "LrLockedException";
74
+ })(LrErrorCode || (LrErrorCode = {}));
75
+ export class LrBadArgumentException extends LrException {
76
+ constructor(message) {
77
+ super({ code: LrErrorCode.BadArgument, message });
78
+ }
79
+ }
80
+ export class LrSuspiciousException extends LrException {
81
+ constructor(message) {
82
+ super({ code: LrErrorCode.BadArgument, message });
83
+ }
84
+ }
85
+ export class LrNotFoundException extends LrException {
86
+ constructor(message) {
87
+ super({ code: LrErrorCode.NotFound, message });
88
+ }
89
+ }
90
+ export class LrBadLogicException extends LrException {
91
+ constructor(message) {
92
+ super({ code: LrErrorCode.BadLogic, message });
93
+ }
94
+ }
95
+ export class LrCodeMismatchException extends LrException {
96
+ constructor(message) {
97
+ super({ code: LrErrorCode.CodeMismatch, message });
98
+ }
99
+ }
100
+ export class LrConcurrentAccessException extends LrException {
101
+ constructor(message) {
102
+ super({ code: LrErrorCode.ConcurrentAccess, message });
103
+ }
104
+ }
105
+ export class LrLockedException extends LrException {
106
+ constructor(message) {
107
+ super({ code: LrErrorCode.Locked, message });
108
+ }
109
+ }
110
+ export class LrBadRequestException extends LrException {
111
+ constructor(message) {
112
+ super({ code: LrErrorCode.BadRequest, message });
113
+ }
114
+ }
115
+ export class LrAuthException extends LrException {
116
+ constructor(message) {
117
+ super({ code: LrErrorCode.Auth, message });
118
+ }
119
+ }
120
+ export class LrEncryptionException extends LrException {
121
+ constructor(message) {
122
+ super({ code: LrErrorCode.Encryption, message });
123
+ }
124
+ }
125
+ export class LrUnsupportedException extends LrException {
126
+ constructor(message) {
127
+ super({
128
+ code: 'LrUnsupportedException',
129
+ message,
130
+ });
131
+ }
132
+ }
133
+ export class LrExpiredCodeException extends LrException {
134
+ constructor(message) {
135
+ super({
136
+ code: 'LrExpiredCodeException',
137
+ message,
138
+ });
139
+ }
140
+ }
141
+ export class LrExpiredException extends LrException {
142
+ constructor(message) {
143
+ super({
144
+ code: 'LrExpiredException',
145
+ message,
146
+ });
147
+ }
148
+ }
149
+ export class LrBadStateException extends LrException {
150
+ constructor(message) {
151
+ super({
152
+ code: 'LrBadStateException',
153
+ message,
154
+ });
155
+ }
156
+ }
157
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"exceptions.js","sourceRoot":"/opt/atlassian/pipelines/agent/build/projects/core/src/","sources":["lib/_common/exceptions.ts"],"names":[],"mappings":"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","sourcesContent":["import { GraphQLError } from 'graphql';\nimport { debuglog } from 'util';\n\nexport function handleApolloError(errors: ReadonlyArray<GraphQLError>) {\n  if (!errors || !errors.length) return;\n\n  const lrErrors = errors.map((x) => ({\n    code: x.extensions && x.extensions.code,\n    source: x.extensions && x.extensions.source,\n    message: x.message,\n    debug: {\n      locations: x.locations as any,\n      path: x.path as string[],\n    },\n  }));\n\n  throw new LrException(...lrErrors);\n}\n\nexport class LrError {\n  code?: string;\n  source?: string;\n  message: string;\n  debug?: {\n    locations: {\n      line: number;\n      column: number;\n    }[];\n    path: string[];\n  };\n}\n\nexport class LrException {\n  public errors: LrError[];\n\n  constructor(...errors: LrError[]) {\n    this.errors = errors;\n  }\n\n  public toString() {\n    return this.errors.map((t) => JSON.stringify(t, null, 2));\n  }\n}\n\nexport enum LrApiErrorCode {\n  ARCHIVED_RESOURCE = 'ARCHIVED_RESOURCE',\n  BAD_ARGUMENT = 'BAD_ARGUMENT',\n  BAD_SIGNATURE = 'BAD_SIGNATURE',\n  BAD_STATE = 'BAD_STATE',\n  CHANGED_PERMISSIONS = 'CHANGED_PERMISSIONS',\n  CONCURRENT_ACCESS = 'CONCURRENT_ACCESS',\n  CONFIG_ERROR = 'CONFIG_ERROR',\n  CYCLE_DETECTED = 'CYCLE_DETECTED',\n  EXPIRED = 'EXPIRED',\n  INVALID_TOKEN = 'INVALID_TOKEN',\n  INTERNAL_ERROR = 'INTERNAL_ERROR',\n  JSON_DECODE_ERROR = 'JSON_DECODE_ERROR',\n  KEY_MISMATCH = 'KEY_MISMATCH',\n  LIMIT_REACHED = 'LIMIT_REACHED',\n  LOCKED = 'LOCKED',\n  LOGIC_ERROR = 'LOGIC_ERROR',\n  LR_DEBUG_ONLY = 'LR_DEBUG_ONLY',\n  MIN_DELAY = 'MIN_DELAY',\n  MISSING_FIELD = 'MISSING_FIELD',\n  MISSING_FIELD_VALUE = 'MISSING_FIELD_VALUE',\n  MISSING_QUERY_PARAM = 'MISSING_QUERY_PARAM',\n  NOT_IMPLEMENTED = 'NOT_IMPLEMENTED',\n  OBJECT_DOES_NOT_EXIST = 'OBJECT_DOES_NOT_EXIST',\n  OBJECT_EXISTS = 'OBJECT_EXISTS',\n  RANGE_ERROR = 'RANGE_ERROR',\n  TRUSTED_PARTY_NOT_FOUND = 'TRUSTED_PARTY_NOT_FOUND',\n  UNAUTHENTICATED_USER = 'UNAUTHENTICATED_USER',\n  USER_NOT_FOUND = 'USER_NOT_FOUND',\n  VERSION_MISMATCH = 'VERSION_MISMATCH',\n  WRONG_PERMISSIONS = 'WRONG_PERMISSIONS',\n}\n\nexport enum LrErrorCode {\n  BadTimeSync = 'LrBadTimeSync',\n  ReceiveClaimMismatch = 'LrReceiveClaimMismatch',\n  BadState = 'LrBadState',\n  BadSignature = 'LrBadSignature',\n  Auth = 'LrAuth',\n  BadArgument = 'LrBadArgument',\n  SuspiciousException = 'LrSuspiciousException',\n  NotFound = 'LrNotFound',\n  BadLogic = 'LrBadLogicException',\n  CodeMismatch = 'LrCodeMismatchException',\n  ConcurrentAccess = 'LrConcurrentAccessException',\n  BadRequest = 'LrBadRequestException',\n  Encryption = 'LrEncryptionGoBad',\n  Locked = 'LrLockedException',\n}\n\nexport class LrBadArgumentException extends LrException {\n  constructor(message) {\n    super({ code: LrErrorCode.BadArgument, message });\n  }\n}\n\nexport class LrSuspiciousException extends LrException {\n  constructor(message) {\n    super({ code: LrErrorCode.BadArgument, message });\n  }\n}\n\nexport class LrNotFoundException extends LrException {\n  constructor(message) {\n    super({ code: LrErrorCode.NotFound, message });\n  }\n}\n\nexport class LrBadLogicException extends LrException {\n  constructor(message) {\n    super({ code: LrErrorCode.BadLogic, message });\n  }\n}\n\nexport class LrCodeMismatchException extends LrException {\n  constructor(message) {\n    super({ code: LrErrorCode.CodeMismatch, message });\n  }\n}\n\nexport class LrConcurrentAccessException extends LrException {\n  constructor(message) {\n    super({ code: LrErrorCode.ConcurrentAccess, message });\n  }\n}\n\nexport class LrLockedException extends LrException {\n  constructor(message) {\n    super({ code: LrErrorCode.Locked, message });\n  }\n}\n\nexport class LrBadRequestException extends LrException {\n  constructor(message) {\n    super({ code: LrErrorCode.BadRequest, message });\n  }\n}\n\nexport class LrAuthException extends LrException {\n  constructor(message) {\n    super({ code: LrErrorCode.Auth, message });\n  }\n}\n\nexport class LrEncryptionException extends LrException {\n  constructor(message) {\n    super({ code: LrErrorCode.Encryption, message });\n  }\n}\n\nexport class LrUnsupportedException extends LrException {\n  constructor(message) {\n    super({\n      code: 'LrUnsupportedException',\n      message,\n    });\n  }\n}\n\nexport class LrExpiredCodeException extends LrException {\n  constructor(message) {\n    super({\n      code: 'LrExpiredCodeException',\n      message,\n    });\n  }\n}\n\nexport class LrExpiredException extends LrException {\n  constructor(message) {\n    super({\n      code: 'LrExpiredException',\n      message,\n    });\n  }\n}\n\nexport class LrBadStateException extends LrException {\n  constructor(message) {\n    super({\n      code: 'LrBadStateException',\n      message,\n    });\n  }\n}\n"]}
@@ -0,0 +1,190 @@
1
+ import gql from 'graphql-tag';
2
+ const KeyGraphFragmentBase = `
3
+ {
4
+ keys {
5
+ id
6
+ }
7
+ keyLinks {
8
+ keyId
9
+ wrappingKeyId
10
+ wrappedKey
11
+ }
12
+ passKeys {
13
+ id
14
+ }
15
+ passKeyLinks {
16
+ keyId
17
+ passKeyId
18
+ wrappedKey
19
+ }
20
+ __typename
21
+ }
22
+ `;
23
+ export const KeyGraphFragment = gql `
24
+ fragment KeyGraphFragment on KeyGraphType ${KeyGraphFragmentBase}
25
+ `;
26
+ export const KeyGraphField = `keyGraph ${KeyGraphFragmentBase}`;
27
+ export const FetchKeyGraphField = `keyGraph: fetchKeyGraph ${KeyGraphFragmentBase}`;
28
+ export const FileQuery = gql `
29
+ query File($id: LrRelayIdInput!, $cachedKeyIds: [LrRelayIdInput!]) {
30
+ file(id: $id) {
31
+ id
32
+ keyId
33
+ currentVersion {
34
+ id
35
+ operation
36
+ state {
37
+ keyId
38
+ plainMeta
39
+ cipherMeta
40
+ contentResource
41
+ }
42
+ }
43
+ versions {
44
+ edges {
45
+ node {
46
+ id
47
+ state {
48
+ keyId
49
+ plainMeta
50
+ cipherMeta
51
+ contentResource
52
+ }
53
+ }
54
+ }
55
+ }
56
+ parentDirectoryLinks {
57
+ edges {
58
+ node {
59
+ parentDirectory {
60
+ id
61
+ plainMeta
62
+ }
63
+ }
64
+ }
65
+ }
66
+ }
67
+ keyGraph(cachedKeyIds: $cachedKeyIds) {
68
+ ...KeyGraphFragment
69
+ }
70
+ }
71
+ ${KeyGraphFragment}
72
+ `;
73
+ export const DirectoryQuery = gql `
74
+ query Directory($id: LrRelayIdInput!, $cachedKeyIds: [LrRelayIdInput!]) {
75
+ directory(id: $id) {
76
+ id
77
+ keyId
78
+ plainMeta
79
+ cipherMeta
80
+ }
81
+ keyGraph(cachedKeyIds: $cachedKeyIds) {
82
+ ...KeyGraphFragment
83
+ }
84
+ }
85
+ ${KeyGraphFragment}
86
+ `;
87
+ export const CreateFileQuery = gql `
88
+ mutation CreateFile($input: CreateFileInput!) {
89
+ createFile(input: $input) {
90
+ file {
91
+ id
92
+ }
93
+ }
94
+ }
95
+ `;
96
+ export const UpdateFileQuery = gql `
97
+ mutation UpdateFile($input: UpdateFileInput!) {
98
+ updateFile(input: $input) {
99
+ file {
100
+ id
101
+ currentVersion {
102
+ id
103
+ state {
104
+ id
105
+ }
106
+ }
107
+ }
108
+ }
109
+ }
110
+ `;
111
+ export const RevertFileQuery = gql `
112
+ mutation RevertFile($input: RevertFileInput!) {
113
+ revertFile(input: $input) {
114
+ file {
115
+ id
116
+ currentVersion {
117
+ id
118
+ state {
119
+ id
120
+ }
121
+ }
122
+ }
123
+ }
124
+ }
125
+ `;
126
+ export const MoveFileQuery = gql `
127
+ mutation MoveFile(
128
+ $fileId: LrRelayIdInput!
129
+ $fromParentDirectoryId: LrRelayIdInput!
130
+ $toParentDirectoryId: LrRelayIdInput!
131
+ $wrappingKeyId: LrRelayIdInput!
132
+ $wrappedKey: String!
133
+ ) {
134
+ moveFile(
135
+ input: {
136
+ fileId: $fileId
137
+ fromParentDirectoryId: $fromParentDirectoryId
138
+ toParentDirectoryId: $toParentDirectoryId
139
+ wrappingKeyId: $wrappingKeyId
140
+ wrappedKey: $wrappedKey
141
+ }
142
+ ) {
143
+ file {
144
+ id
145
+ parentDirectoryLinks {
146
+ edges {
147
+ node {
148
+ parentDirectory {
149
+ plainMeta
150
+ }
151
+ }
152
+ }
153
+ }
154
+ }
155
+ }
156
+ }
157
+ `;
158
+ export const MoveDirectoryQuery = gql `
159
+ mutation MoveDirectory(
160
+ $directoryId: LrRelayIdInput!
161
+ $fromParentDirectoryId: LrRelayIdInput
162
+ $toParentDirectoryId: LrRelayIdInput!
163
+ $wrappedKey: String!
164
+ $wrappingKeyId: LrRelayIdInput!
165
+ ) {
166
+ moveDirectory(
167
+ input: {
168
+ directoryId: $directoryId
169
+ fromParentDirectoryId: $fromParentDirectoryId
170
+ toParentDirectoryId: $toParentDirectoryId
171
+ wrappedKey: $wrappedKey
172
+ wrappingKeyId: $wrappingKeyId
173
+ }
174
+ ) {
175
+ directory {
176
+ id
177
+ parentDirectoryLinks {
178
+ edges {
179
+ node {
180
+ parentDirectory {
181
+ plainMeta
182
+ }
183
+ }
184
+ }
185
+ }
186
+ }
187
+ }
188
+ }
189
+ `;
190
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicXVlcmllcy5ncWwuanMiLCJzb3VyY2VSb290IjoiL29wdC9hdGxhc3NpYW4vcGlwZWxpbmVzL2FnZW50L2J1aWxkL3Byb2plY3RzL2NvcmUvc3JjLyIsInNvdXJjZXMiOlsibGliL19jb21tb24vcXVlcmllcy5ncWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxHQUFHLE1BQU0sYUFBYSxDQUFDO0FBRTlCLE1BQU0sb0JBQW9CLEdBQUc7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0NBb0I1QixDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sZ0JBQWdCLEdBQUcsR0FBRyxDQUFBOzRDQUNTLG9CQUFvQjtDQUMvRCxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sYUFBYSxHQUFHLFlBQVksb0JBQW9CLEVBQUUsQ0FBQztBQUVoRSxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRywyQkFBMkIsb0JBQW9CLEVBQUUsQ0FBQztBQUVwRixNQUFNLENBQUMsTUFBTSxTQUFTLEdBQUcsR0FBRyxDQUFBOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0lBMkN4QixnQkFBZ0I7Q0FDbkIsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRyxHQUFHLENBQUE7Ozs7Ozs7Ozs7OztJQVk3QixnQkFBZ0I7Q0FDbkIsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBRyxHQUFHLENBQUE7Ozs7Ozs7O0NBUWpDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxlQUFlLEdBQUcsR0FBRyxDQUFBOzs7Ozs7Ozs7Ozs7OztDQWNqQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sZUFBZSxHQUFHLEdBQUcsQ0FBQTs7Ozs7Ozs7Ozs7Ozs7Q0FjakMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLGFBQWEsR0FBRyxHQUFHLENBQUE7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Q0ErQi9CLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxHQUFHLENBQUE7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Q0ErQnBDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgZ3FsIGZyb20gJ2dyYXBocWwtdGFnJztcblxuY29uc3QgS2V5R3JhcGhGcmFnbWVudEJhc2UgPSBgXG57XG4gIGtleXMge1xuICAgIGlkXG4gIH1cbiAga2V5TGlua3Mge1xuICAgIGtleUlkXG4gICAgd3JhcHBpbmdLZXlJZFxuICAgIHdyYXBwZWRLZXlcbiAgfVxuICBwYXNzS2V5cyB7XG4gICAgaWRcbiAgfVxuICBwYXNzS2V5TGlua3Mge1xuICAgIGtleUlkXG4gICAgcGFzc0tleUlkXG4gICAgd3JhcHBlZEtleVxuICB9XG4gIF9fdHlwZW5hbWVcbn1cbmA7XG5cbmV4cG9ydCBjb25zdCBLZXlHcmFwaEZyYWdtZW50ID0gZ3FsYFxuZnJhZ21lbnQgS2V5R3JhcGhGcmFnbWVudCBvbiBLZXlHcmFwaFR5cGUgJHtLZXlHcmFwaEZyYWdtZW50QmFzZX1cbmA7XG5cbmV4cG9ydCBjb25zdCBLZXlHcmFwaEZpZWxkID0gYGtleUdyYXBoICR7S2V5R3JhcGhGcmFnbWVudEJhc2V9YDtcblxuZXhwb3J0IGNvbnN0IEZldGNoS2V5R3JhcGhGaWVsZCA9IGBrZXlHcmFwaDogZmV0Y2hLZXlHcmFwaCAke0tleUdyYXBoRnJhZ21lbnRCYXNlfWA7XG5cbmV4cG9ydCBjb25zdCBGaWxlUXVlcnkgPSBncWxgXG4gIHF1ZXJ5IEZpbGUoJGlkOiBMclJlbGF5SWRJbnB1dCEsICRjYWNoZWRLZXlJZHM6IFtMclJlbGF5SWRJbnB1dCFdKSB7XG4gICAgZmlsZShpZDogJGlkKSB7XG4gICAgICBpZFxuICAgICAga2V5SWRcbiAgICAgIGN1cnJlbnRWZXJzaW9uIHtcbiAgICAgICAgaWRcbiAgICAgICAgb3BlcmF0aW9uXG4gICAgICAgIHN0YXRlIHtcbiAgICAgICAgICBrZXlJZFxuICAgICAgICAgIHBsYWluTWV0YVxuICAgICAgICAgIGNpcGhlck1ldGFcbiAgICAgICAgICBjb250ZW50UmVzb3VyY2VcbiAgICAgICAgfVxuICAgICAgfVxuICAgICAgdmVyc2lvbnMge1xuICAgICAgICBlZGdlcyB7XG4gICAgICAgICAgbm9kZSB7XG4gICAgICAgICAgICBpZFxuICAgICAgICAgICAgc3RhdGUge1xuICAgICAgICAgICAgICBrZXlJZFxuICAgICAgICAgICAgICBwbGFpbk1ldGFcbiAgICAgICAgICAgICAgY2lwaGVyTWV0YVxuICAgICAgICAgICAgICBjb250ZW50UmVzb3VyY2VcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICAgIHBhcmVudERpcmVjdG9yeUxpbmtzIHtcbiAgICAgICAgZWRnZXMge1xuICAgICAgICAgIG5vZGUge1xuICAgICAgICAgICAgcGFyZW50RGlyZWN0b3J5IHtcbiAgICAgICAgICAgICAgaWRcbiAgICAgICAgICAgICAgcGxhaW5NZXRhXG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuICAgIGtleUdyYXBoKGNhY2hlZEtleUlkczogJGNhY2hlZEtleUlkcykge1xuICAgICAgLi4uS2V5R3JhcGhGcmFnbWVudFxuICAgIH1cbiAgfVxuICAke0tleUdyYXBoRnJhZ21lbnR9XG5gO1xuXG5leHBvcnQgY29uc3QgRGlyZWN0b3J5UXVlcnkgPSBncWxgXG4gIHF1ZXJ5IERpcmVjdG9yeSgkaWQ6IExyUmVsYXlJZElucHV0ISwgJGNhY2hlZEtleUlkczogW0xyUmVsYXlJZElucHV0IV0pIHtcbiAgICBkaXJlY3RvcnkoaWQ6ICRpZCkge1xuICAgICAgaWRcbiAgICAgIGtleUlkXG4gICAgICBwbGFpbk1ldGFcbiAgICAgIGNpcGhlck1ldGFcbiAgICB9XG4gICAga2V5R3JhcGgoY2FjaGVkS2V5SWRzOiAkY2FjaGVkS2V5SWRzKSB7XG4gICAgICAuLi5LZXlHcmFwaEZyYWdtZW50XG4gICAgfVxuICB9XG4gICR7S2V5R3JhcGhGcmFnbWVudH1cbmA7XG5cbmV4cG9ydCBjb25zdCBDcmVhdGVGaWxlUXVlcnkgPSBncWxgXG4gIG11dGF0aW9uIENyZWF0ZUZpbGUoJGlucHV0OiBDcmVhdGVGaWxlSW5wdXQhKSB7XG4gICAgY3JlYXRlRmlsZShpbnB1dDogJGlucHV0KSB7XG4gICAgICBmaWxlIHtcbiAgICAgICAgaWRcbiAgICAgIH1cbiAgICB9XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBVcGRhdGVGaWxlUXVlcnkgPSBncWxgXG4gIG11dGF0aW9uIFVwZGF0ZUZpbGUoJGlucHV0OiBVcGRhdGVGaWxlSW5wdXQhKSB7XG4gICAgdXBkYXRlRmlsZShpbnB1dDogJGlucHV0KSB7XG4gICAgICBmaWxlIHtcbiAgICAgICAgaWRcbiAgICAgICAgY3VycmVudFZlcnNpb24ge1xuICAgICAgICAgIGlkXG4gICAgICAgICAgc3RhdGUge1xuICAgICAgICAgICAgaWRcbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBSZXZlcnRGaWxlUXVlcnkgPSBncWxgXG4gIG11dGF0aW9uIFJldmVydEZpbGUoJGlucHV0OiBSZXZlcnRGaWxlSW5wdXQhKSB7XG4gICAgcmV2ZXJ0RmlsZShpbnB1dDogJGlucHV0KSB7XG4gICAgICBmaWxlIHtcbiAgICAgICAgaWRcbiAgICAgICAgY3VycmVudFZlcnNpb24ge1xuICAgICAgICAgIGlkXG4gICAgICAgICAgc3RhdGUge1xuICAgICAgICAgICAgaWRcbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBNb3ZlRmlsZVF1ZXJ5ID0gZ3FsYFxuICBtdXRhdGlvbiBNb3ZlRmlsZShcbiAgICAkZmlsZUlkOiBMclJlbGF5SWRJbnB1dCFcbiAgICAkZnJvbVBhcmVudERpcmVjdG9yeUlkOiBMclJlbGF5SWRJbnB1dCFcbiAgICAkdG9QYXJlbnREaXJlY3RvcnlJZDogTHJSZWxheUlkSW5wdXQhXG4gICAgJHdyYXBwaW5nS2V5SWQ6IExyUmVsYXlJZElucHV0IVxuICAgICR3cmFwcGVkS2V5OiBTdHJpbmchXG4gICkge1xuICAgIG1vdmVGaWxlKFxuICAgICAgaW5wdXQ6IHtcbiAgICAgICAgZmlsZUlkOiAkZmlsZUlkXG4gICAgICAgIGZyb21QYXJlbnREaXJlY3RvcnlJZDogJGZyb21QYXJlbnREaXJlY3RvcnlJZFxuICAgICAgICB0b1BhcmVudERpcmVjdG9yeUlkOiAkdG9QYXJlbnREaXJlY3RvcnlJZFxuICAgICAgICB3cmFwcGluZ0tleUlkOiAkd3JhcHBpbmdLZXlJZFxuICAgICAgICB3cmFwcGVkS2V5OiAkd3JhcHBlZEtleVxuICAgICAgfVxuICAgICkge1xuICAgICAgZmlsZSB7XG4gICAgICAgIGlkXG4gICAgICAgIHBhcmVudERpcmVjdG9yeUxpbmtzIHtcbiAgICAgICAgICBlZGdlcyB7XG4gICAgICAgICAgICBub2RlIHtcbiAgICAgICAgICAgICAgcGFyZW50RGlyZWN0b3J5IHtcbiAgICAgICAgICAgICAgICBwbGFpbk1ldGFcbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IE1vdmVEaXJlY3RvcnlRdWVyeSA9IGdxbGBcbiAgbXV0YXRpb24gTW92ZURpcmVjdG9yeShcbiAgICAkZGlyZWN0b3J5SWQ6IExyUmVsYXlJZElucHV0IVxuICAgICRmcm9tUGFyZW50RGlyZWN0b3J5SWQ6IExyUmVsYXlJZElucHV0XG4gICAgJHRvUGFyZW50RGlyZWN0b3J5SWQ6IExyUmVsYXlJZElucHV0IVxuICAgICR3cmFwcGVkS2V5OiBTdHJpbmchXG4gICAgJHdyYXBwaW5nS2V5SWQ6IExyUmVsYXlJZElucHV0IVxuICApIHtcbiAgICBtb3ZlRGlyZWN0b3J5KFxuICAgICAgaW5wdXQ6IHtcbiAgICAgICAgZGlyZWN0b3J5SWQ6ICRkaXJlY3RvcnlJZFxuICAgICAgICBmcm9tUGFyZW50RGlyZWN0b3J5SWQ6ICRmcm9tUGFyZW50RGlyZWN0b3J5SWRcbiAgICAgICAgdG9QYXJlbnREaXJlY3RvcnlJZDogJHRvUGFyZW50RGlyZWN0b3J5SWRcbiAgICAgICAgd3JhcHBlZEtleTogJHdyYXBwZWRLZXlcbiAgICAgICAgd3JhcHBpbmdLZXlJZDogJHdyYXBwaW5nS2V5SWRcbiAgICAgIH1cbiAgICApIHtcbiAgICAgIGRpcmVjdG9yeSB7XG4gICAgICAgIGlkXG4gICAgICAgIHBhcmVudERpcmVjdG9yeUxpbmtzIHtcbiAgICAgICAgICBlZGdlcyB7XG4gICAgICAgICAgICBub2RlIHtcbiAgICAgICAgICAgICAgcGFyZW50RGlyZWN0b3J5IHtcbiAgICAgICAgICAgICAgICBwbGFpbk1ldGFcbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cbiAgfVxuYDtcbiJdfQ==
@@ -0,0 +1,79 @@
1
+ import { LrBadLogicException } from '../_common/exceptions';
2
+ /**
3
+ * If you wish to change the behaviour of those, you'll need to create a derived
4
+ * class and override the methods.
5
+ * However, can't figure out a way to call the super() in the derived class ctor, error says
6
+ * the super call can't be in tested function.
7
+ */
8
+ export const EXCLUDE_METHODS = [
9
+ 'constructor',
10
+ 'ngOnChanges',
11
+ 'ngOnInit',
12
+ 'ngDoCheck',
13
+ 'ngAfterContentInit',
14
+ 'ngAfterContentChecked',
15
+ 'ngAfterViewInit',
16
+ 'ngAfterViewChecked',
17
+ 'ngOnDestroy',
18
+ ];
19
+ // Patch all methods of the class.
20
+ //
21
+ // Note, this will not patch functions in the base class, it only
22
+ // patches the function defined in the current class because it's
23
+ // using getOwnPropertyNames(). You should be using composition for
24
+ // services anyway.
25
+ //
26
+ // Ref: https://stackoverflow.com/a/44409244
27
+ // The above approach might be a bit old. Now that we have ngZone.runOutsideAngular(),
28
+ // we should probably use that and not touch any angular zone internals. But the approach
29
+ // above doesn't require injecting ngZone.
30
+ //
31
+ // Ref: https://github.com/2ng/run-outside-angular/blob/master/src/run-outside-angular.ts
32
+ export function RunOutsideAngular({ ngZoneName, exceptLastPromise = true, excludeMethods = [], patchSetters = true, }) {
33
+ return (target) => {
34
+ function run(original, args) {
35
+ if (!this[ngZoneName]) {
36
+ throw new LrBadLogicException(`RunOutsideAngular decorator requires that ${target.name} inject NgZone as ${ngZoneName}`);
37
+ }
38
+ // runOutsideAngular() synchronously runs the callback and returns the result.
39
+ const result = this[ngZoneName].runOutsideAngular(() => original.apply(this, args));
40
+ if (exceptLastPromise && (result === null || result === void 0 ? void 0 : result.then)) {
41
+ // Bring back into zone which will trigger change detection properly.
42
+ // If this doesn't work, then we'll have to trigger change detection explicitly.
43
+ return Promise.resolve(result);
44
+ }
45
+ else {
46
+ return result;
47
+ }
48
+ }
49
+ // There should be no reason to run any of the ones in EXCLUDE_METHODS outside angular.
50
+ // So we always exclude them from patching. You can always explicit implement these ones differently.
51
+ excludeMethods = [...excludeMethods, ...EXCLUDE_METHODS];
52
+ const methods = Object.getOwnPropertyNames(target.prototype);
53
+ methods
54
+ .filter((method) => !excludeMethods.includes(method))
55
+ .forEach((method) => {
56
+ // Patch setters
57
+ // Note that setters do not return any thing. But they can still issue async calls.
58
+ // These async calls are not visible to the wrapper. So we can't issue change detection
59
+ // for setters when they are running outside angular.
60
+ if (patchSetters &&
61
+ Object.getOwnPropertyDescriptor(target.prototype, method).set) {
62
+ const original = Object.getOwnPropertyDescriptor(target.prototype, method).set;
63
+ Object.defineProperty(target.prototype, method, {
64
+ set(...args) {
65
+ return run.apply(this, [original, args]);
66
+ },
67
+ });
68
+ }
69
+ if (typeof target.prototype[method] === 'function') {
70
+ const original = target.prototype[method];
71
+ target.prototype[method] = function (...args) {
72
+ return run.apply(this, [original, args]);
73
+ };
74
+ }
75
+ });
76
+ return target;
77
+ };
78
+ }
79
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"run-outside-angular.js","sourceRoot":"/opt/atlassian/pipelines/agent/build/projects/core/src/","sources":["lib/_common/run-outside-angular.ts"],"names":[],"mappings":"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","sourcesContent":["import { LrBadLogicException } from '../_common/exceptions';\n\nexport interface RunOutsideAngularConfig {\n  ngZoneName: string;\n  // If true, a single change detection is triggered on resolve of the Promise returned\n  // from the function.\n  // else, the entire function is run outside of zone.\n  // Note that if this is disabled, then change detection is not triggered even if you\n  // use async pipes to subscribe to observables on the resulting promise. This is because\n  // async pipes only _marks_ a component for change detection, it doesn't actually _trigger_\n  // the change detection cycle.\n  exceptLastPromise?: boolean;\n  // Any method or property you wish to exclude from patch. The methods in EXCLUDE_METHODS are\n  // never patched.\n  excludeMethods?: string[];\n  // If true, patch the setters as well. Settings are some\n  // Note that setters do not return any thing. But they can still issue async calls.\n  // These async calls are not visible to the wrapper. So we can't issue change detection\n  // for setters when they are running outside angular.\n  // Note that getters are not patched because getter and setter must use the same type. So if\n  // the getter returns a promise, then the setting must alway take a promise. It doesn't make\n  // much sense to use getters and setters this way. And if getter returns a value, then there's\n  // no need to patch it to run outside angular.\n  patchSetters?: boolean;\n}\n\n/**\n * If you wish to change the behaviour of those, you'll need to create a derived\n * class and override the methods.\n * However, can't figure out a way to call the super() in the derived class ctor, error says\n * the super call can't be in tested function.\n */\nexport const EXCLUDE_METHODS = [\n  'constructor',\n  'ngOnChanges',\n  'ngOnInit',\n  'ngDoCheck',\n  'ngAfterContentInit',\n  'ngAfterContentChecked',\n  'ngAfterViewInit',\n  'ngAfterViewChecked',\n  'ngOnDestroy',\n];\n\n// Patch all methods of the class.\n//\n// Note, this will not patch functions in the base class, it only\n// patches the function defined in the current class because it's\n// using getOwnPropertyNames(). You should be using composition for\n// services anyway.\n//\n// Ref: https://stackoverflow.com/a/44409244\n// The above approach might be a bit old. Now that we have ngZone.runOutsideAngular(),\n// we should probably use that and not touch any angular zone internals. But the approach\n// above doesn't require injecting ngZone.\n//\n// Ref: https://github.com/2ng/run-outside-angular/blob/master/src/run-outside-angular.ts\nexport function RunOutsideAngular({\n  ngZoneName,\n  exceptLastPromise = true,\n  excludeMethods = [],\n  patchSetters = true,\n}: RunOutsideAngularConfig) {\n  return (target: any) => {\n    function run(original, args) {\n      if (!this[ngZoneName]) {\n        throw new LrBadLogicException(\n          `RunOutsideAngular decorator requires that ${target.name} inject NgZone as ${ngZoneName}`\n        );\n      }\n      // runOutsideAngular() synchronously runs the callback and returns the result.\n      const result = this[ngZoneName].runOutsideAngular(() =>\n        original.apply(this, args)\n      );\n\n      if (exceptLastPromise && result?.then) {\n        // Bring back into zone which will trigger change detection properly.\n        // If this doesn't work, then we'll have to trigger change detection explicitly.\n        return Promise.resolve(result);\n      } else {\n        return result;\n      }\n    }\n\n    // There should be no reason to run any of the ones in EXCLUDE_METHODS outside angular.\n    // So we always exclude them from patching. You can always explicit implement these ones differently.\n    excludeMethods = [...excludeMethods, ...EXCLUDE_METHODS];\n\n    const methods = Object.getOwnPropertyNames(target.prototype);\n\n    methods\n      .filter((method) => !excludeMethods.includes(method))\n      .forEach((method) => {\n        // Patch setters\n        // Note that setters do not return any thing. But they can still issue async calls.\n        // These async calls are not visible to the wrapper. So we can't issue change detection\n        // for setters when they are running outside angular.\n        if (\n          patchSetters &&\n          Object.getOwnPropertyDescriptor(target.prototype, method).set\n        ) {\n          const original = Object.getOwnPropertyDescriptor(\n            target.prototype,\n            method\n          ).set;\n\n          Object.defineProperty(target.prototype, method, {\n            set(...args) {\n              return run.apply(this, [original, args]);\n            },\n          });\n        }\n\n        if (typeof target.prototype[method] === 'function') {\n          const original = target.prototype[method];\n\n          target.prototype[method] = function(...args) {\n            return run.apply(this, [original, args]);\n          };\n        }\n      });\n\n    return target;\n  };\n}\n"]}
@@ -0,0 +1 @@
1
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiL29wdC9hdGxhc3NpYW4vcGlwZWxpbmVzL2FnZW50L2J1aWxkL3Byb2plY3RzL2NvcmUvc3JjLyIsInNvdXJjZXMiOlsibGliL19jb21tb24vdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEhhc0tleUdyYXBoIH0gZnJvbSAnLi4vY3J5cHRvZ3JhcGh5L2NyeXB0b2dyYXBoeS50eXBlcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRWRnZTxUPiB7XG4gIG5vZGU6IFQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSGFzRWRnZXM8VD4ge1xuICBlZGdlczogRWRnZTxUPltdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEhhc0tleUdyYXBoRWRnZXM8VD4gZXh0ZW5kcyBIYXNLZXlHcmFwaCB7XG4gIGxpc3Q6IEhhc0VkZ2VzPFQ+O1xufVxuIl19
@@ -0,0 +1,44 @@
1
+ // Promise.all always returns a promise, even if all the values are not async.
2
+ // During processing of deep hierarchies of nested objects we don't always need to
3
+ // promote everything to a promise.
4
+ export function promiseAllMayAsync(values) {
5
+ if (!Array.isArray(values)) {
6
+ throw new Error('not array');
7
+ }
8
+ if (values.some((value) => value === null || value === void 0 ? void 0 : value.then)) {
9
+ const ret = Promise.all(values);
10
+ return ret;
11
+ }
12
+ else {
13
+ return values;
14
+ }
15
+ }
16
+ function remap(obj, values) {
17
+ const ret = {};
18
+ for (const [i, key] of Object.keys(obj).entries()) {
19
+ ret[key] = values[i];
20
+ }
21
+ return ret;
22
+ }
23
+ export function mapValuesMayAsync(obj,
24
+ // callback can either return a Promise, or a value.
25
+ // The Promise<any> type is redundant but it shows that it can return a promise
26
+ callback) {
27
+ const values = promiseAllMayAsync(Object.entries(obj).map(([key, value]) => callback(value, key, obj)));
28
+ if (values.then) {
29
+ return values.then((resolvedValues) => remap(obj, resolvedValues));
30
+ }
31
+ else {
32
+ return remap(obj, values);
33
+ }
34
+ }
35
+ export function mapValuesAsync(obj,
36
+ // callback can either return a Promise, or a value.
37
+ // The Promise<any> type is redundant but it shows that it can return a promise
38
+ // By default, it returns the value without any process, so you can use
39
+ // this to simply wait for all promises in an object to resolve.
40
+ callback) {
41
+ const values = Promise.all(Object.entries(obj).map(([key, value]) => callback ? callback(value, key, obj) : value));
42
+ return values.then((resolvedValues) => remap(obj, resolvedValues));
43
+ }
44
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiL29wdC9hdGxhc3NpYW4vcGlwZWxpbmVzL2FnZW50L2J1aWxkL3Byb2plY3RzL2NvcmUvc3JjLyIsInNvdXJjZXMiOlsibGliL19jb21tb24vdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsOEVBQThFO0FBQzlFLGtGQUFrRjtBQUVsRixtQ0FBbUM7QUFDbkMsTUFBTSxVQUFVLGtCQUFrQixDQUFDLE1BQWE7SUFDOUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLEVBQUU7UUFDMUIsTUFBTSxJQUFJLEtBQUssQ0FBQyxXQUFXLENBQUMsQ0FBQztLQUM5QjtJQUNELElBQUksTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsS0FBSyxhQUFMLEtBQUssdUJBQUwsS0FBSyxDQUFFLElBQUksQ0FBQyxFQUFFO1FBQ3ZDLE1BQU0sR0FBRyxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDaEMsT0FBTyxHQUFHLENBQUM7S0FDWjtTQUFNO1FBQ0wsT0FBTyxNQUFNLENBQUM7S0FDZjtBQUNILENBQUM7QUFFRCxTQUFTLEtBQUssQ0FBQyxHQUFHLEVBQUUsTUFBTTtJQUN4QixNQUFNLEdBQUcsR0FBRyxFQUFFLENBQUM7SUFDZixLQUFLLE1BQU0sQ0FBQyxDQUFDLEVBQUUsR0FBRyxDQUFDLElBQUksTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxPQUFPLEVBQUUsRUFBRTtRQUNqRCxHQUFHLENBQUMsR0FBRyxDQUFDLEdBQUcsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDO0tBQ3RCO0lBQ0QsT0FBTyxHQUFHLENBQUM7QUFDYixDQUFDO0FBRUQsTUFBTSxVQUFVLGlCQUFpQixDQUMvQixHQUFXO0FBQ1gsb0RBQW9EO0FBQ3BELCtFQUErRTtBQUMvRSxRQUFzRTtJQUV0RSxNQUFNLE1BQU0sR0FBRyxrQkFBa0IsQ0FDL0IsTUFBTSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEdBQUcsRUFBRSxLQUFLLENBQUMsRUFBRSxFQUFFLENBQUMsUUFBUSxDQUFDLEtBQUssRUFBRSxHQUFHLEVBQUUsR0FBRyxDQUFDLENBQUMsQ0FDckUsQ0FBQztJQUVGLElBQUksTUFBTSxDQUFDLElBQUksRUFBRTtRQUNmLE9BQU8sTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLGNBQWMsRUFBRSxFQUFFLENBQUMsS0FBSyxDQUFDLEdBQUcsRUFBRSxjQUFjLENBQUMsQ0FBQyxDQUFDO0tBQ3BFO1NBQU07UUFDTCxPQUFPLEtBQUssQ0FBQyxHQUFHLEVBQUUsTUFBTSxDQUFDLENBQUM7S0FDM0I7QUFDSCxDQUFDO0FBRUQsTUFBTSxVQUFVLGNBQWMsQ0FDNUIsR0FBVztBQUNYLG9EQUFvRDtBQUNwRCwrRUFBK0U7QUFDL0UsdUVBQXVFO0FBQ3ZFLGdFQUFnRTtBQUNoRSxRQUF1RTtJQUV2RSxNQUFNLE1BQU0sR0FBRyxPQUFPLENBQUMsR0FBRyxDQUN4QixNQUFNLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxFQUFFLEVBQUUsQ0FDdkMsUUFBUSxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsS0FBSyxFQUFFLEdBQUcsRUFBRSxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUM3QyxDQUNGLENBQUM7SUFFRixPQUFPLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQyxjQUFjLEVBQUUsRUFBRSxDQUFDLEtBQUssQ0FBQyxHQUFHLEVBQUUsY0FBYyxDQUFDLENBQUMsQ0FBQztBQUNyRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gUHJvbWlzZS5hbGwgYWx3YXlzIHJldHVybnMgYSBwcm9taXNlLCBldmVuIGlmIGFsbCB0aGUgdmFsdWVzIGFyZSBub3QgYXN5bmMuXG4vLyBEdXJpbmcgcHJvY2Vzc2luZyBvZiBkZWVwIGhpZXJhcmNoaWVzIG9mIG5lc3RlZCBvYmplY3RzIHdlIGRvbid0IGFsd2F5cyBuZWVkIHRvXG5cbi8vIHByb21vdGUgZXZlcnl0aGluZyB0byBhIHByb21pc2UuXG5leHBvcnQgZnVuY3Rpb24gcHJvbWlzZUFsbE1heUFzeW5jKHZhbHVlczogYW55W10pOiBQcm9taXNlPGFueT4gfCBhbnkge1xuICBpZiAoIUFycmF5LmlzQXJyYXkodmFsdWVzKSkge1xuICAgIHRocm93IG5ldyBFcnJvcignbm90IGFycmF5Jyk7XG4gIH1cbiAgaWYgKHZhbHVlcy5zb21lKCh2YWx1ZSkgPT4gdmFsdWU/LnRoZW4pKSB7XG4gICAgY29uc3QgcmV0ID0gUHJvbWlzZS5hbGwodmFsdWVzKTtcbiAgICByZXR1cm4gcmV0O1xuICB9IGVsc2Uge1xuICAgIHJldHVybiB2YWx1ZXM7XG4gIH1cbn1cblxuZnVuY3Rpb24gcmVtYXAob2JqLCB2YWx1ZXMpIHtcbiAgY29uc3QgcmV0ID0ge307XG4gIGZvciAoY29uc3QgW2ksIGtleV0gb2YgT2JqZWN0LmtleXMob2JqKS5lbnRyaWVzKCkpIHtcbiAgICByZXRba2V5XSA9IHZhbHVlc1tpXTtcbiAgfVxuICByZXR1cm4gcmV0O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gbWFwVmFsdWVzTWF5QXN5bmMoXG4gIG9iajogb2JqZWN0LFxuICAvLyBjYWxsYmFjayBjYW4gZWl0aGVyIHJldHVybiBhIFByb21pc2UsIG9yIGEgdmFsdWUuXG4gIC8vIFRoZSBQcm9taXNlPGFueT4gdHlwZSBpcyByZWR1bmRhbnQgYnV0IGl0IHNob3dzIHRoYXQgaXQgY2FuIHJldHVybiBhIHByb21pc2VcbiAgY2FsbGJhY2s6ICh2YWx1ZTogYW55LCBrZXk6IHN0cmluZywgb2JqOiBvYmplY3QpID0+IGFueSB8IFByb21pc2U8YW55PlxuKTogUHJvbWlzZTxhbnk+IHwgYW55IHtcbiAgY29uc3QgdmFsdWVzID0gcHJvbWlzZUFsbE1heUFzeW5jKFxuICAgIE9iamVjdC5lbnRyaWVzKG9iaikubWFwKChba2V5LCB2YWx1ZV0pID0+IGNhbGxiYWNrKHZhbHVlLCBrZXksIG9iaikpXG4gICk7XG5cbiAgaWYgKHZhbHVlcy50aGVuKSB7XG4gICAgcmV0dXJuIHZhbHVlcy50aGVuKChyZXNvbHZlZFZhbHVlcykgPT4gcmVtYXAob2JqLCByZXNvbHZlZFZhbHVlcykpO1xuICB9IGVsc2Uge1xuICAgIHJldHVybiByZW1hcChvYmosIHZhbHVlcyk7XG4gIH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIG1hcFZhbHVlc0FzeW5jKFxuICBvYmo6IG9iamVjdCxcbiAgLy8gY2FsbGJhY2sgY2FuIGVpdGhlciByZXR1cm4gYSBQcm9taXNlLCBvciBhIHZhbHVlLlxuICAvLyBUaGUgUHJvbWlzZTxhbnk+IHR5cGUgaXMgcmVkdW5kYW50IGJ1dCBpdCBzaG93cyB0aGF0IGl0IGNhbiByZXR1cm4gYSBwcm9taXNlXG4gIC8vIEJ5IGRlZmF1bHQsIGl0IHJldHVybnMgdGhlIHZhbHVlIHdpdGhvdXQgYW55IHByb2Nlc3MsIHNvIHlvdSBjYW4gdXNlXG4gIC8vIHRoaXMgdG8gc2ltcGx5IHdhaXQgZm9yIGFsbCBwcm9taXNlcyBpbiBhbiBvYmplY3QgdG8gcmVzb2x2ZS5cbiAgY2FsbGJhY2s/OiAodmFsdWU6IGFueSwga2V5OiBzdHJpbmcsIG9iajogb2JqZWN0KSA9PiBhbnkgfCBQcm9taXNlPGFueT5cbik6IFByb21pc2U8YW55PiB7XG4gIGNvbnN0IHZhbHVlcyA9IFByb21pc2UuYWxsKFxuICAgIE9iamVjdC5lbnRyaWVzKG9iaikubWFwKChba2V5LCB2YWx1ZV0pID0+XG4gICAgICBjYWxsYmFjayA/IGNhbGxiYWNrKHZhbHVlLCBrZXksIG9iaikgOiB2YWx1ZVxuICAgIClcbiAgKTtcblxuICByZXR1cm4gdmFsdWVzLnRoZW4oKHJlc29sdmVkVmFsdWVzKSA9PiByZW1hcChvYmosIHJlc29sdmVkVmFsdWVzKSk7XG59XG4iXX0=