@lifeready/core 0.6.0-beta.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (225) hide show
  1. package/README.md +62 -0
  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 +2 -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 +333 -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 +266 -0
  98. package/esm2015/lib/trusted-parties/tp-password-reset.gql.js +232 -0
  99. package/esm2015/lib/trusted-parties/tp-password-reset.service.js +300 -0
  100. package/esm2015/lib/trusted-parties/trusted-party.gql.js +148 -0
  101. package/esm2015/lib/trusted-parties/trusted-party.service.js +326 -0
  102. package/esm2015/lib/trusted-parties/trusted-party.types.js +41 -0
  103. package/esm2015/lib/trusted-parties/trusted-party2.gql.js +87 -0
  104. package/esm2015/lib/trusted-parties/trusted-party2.service.js +215 -0
  105. package/esm2015/lib/users/profile-details.service.js +214 -0
  106. package/esm2015/lib/users/profile.gql.js +97 -0
  107. package/esm2015/lib/users/profile.service.js +169 -0
  108. package/esm2015/lib/users/profile.types.js +34 -0
  109. package/esm2015/lib/users/user.gql.js +60 -0
  110. package/esm2015/lib/users/user.service.js +79 -0
  111. package/esm2015/lib/users/user.types.js +5 -0
  112. package/esm2015/lifeready-core.js +10 -0
  113. package/esm2015/public-api.js +81 -0
  114. package/fesm2015/lifeready-core.js +13290 -0
  115. package/fesm2015/lifeready-core.js.map +1 -0
  116. package/lib/_common/ast.d.ts +11 -0
  117. package/lib/_common/deferred-promise.d.ts +12 -0
  118. package/lib/_common/exceptions.d.ts +109 -0
  119. package/lib/_common/queries.gql.d.ts +10 -0
  120. package/lib/_common/run-outside-angular.d.ts +14 -0
  121. package/lib/_common/types.d.ts +10 -0
  122. package/lib/_common/utils.d.ts +3 -0
  123. package/lib/api/contact-card.gql.d.ts +7 -0
  124. package/lib/api/contact-card.service.d.ts +52 -0
  125. package/lib/api/contact-card2.gql.d.ts +34 -0
  126. package/lib/api/contact-card2.service.d.ts +49 -0
  127. package/lib/api/file.service.d.ts +18 -0
  128. package/lib/api/item2.gql.d.ts +96 -0
  129. package/lib/api/item2.service.d.ts +177 -0
  130. package/lib/api/key-exchange.gql.d.ts +9 -0
  131. package/lib/api/key-exchange.service.d.ts +39 -0
  132. package/lib/api/key-exchange.types.d.ts +196 -0
  133. package/lib/api/key-exchange2.gql.d.ts +125 -0
  134. package/lib/api/key-exchange2.service.d.ts +187 -0
  135. package/lib/api/lock.gql.d.ts +27 -0
  136. package/lib/api/lock.service.d.ts +25 -0
  137. package/lib/api/lr-apollo.service.d.ts +15 -0
  138. package/lib/api/lr-graphql/index.d.ts +5 -0
  139. package/lib/api/lr-graphql/lr-graphql.service.d.ts +60 -0
  140. package/lib/api/lr-graphql/lr-merged-mutation.d.ts +27 -0
  141. package/lib/api/lr-graphql/lr-mutation-base.d.ts +28 -0
  142. package/lib/api/lr-graphql/lr-mutation.d.ts +8 -0
  143. package/lib/api/lr-graphql/lr.service.d.ts +9 -0
  144. package/lib/api/message.service.d.ts +58 -0
  145. package/lib/api/persist.service.d.ts +31 -0
  146. package/lib/api/query-processor/common-processors.service.d.ts +36 -0
  147. package/lib/api/query-processor/index.d.ts +2 -0
  148. package/lib/api/query-processor/query-processor.service.d.ts +18 -0
  149. package/lib/api/query-processor/tp-password-reset-processor.service.d.ts +15 -0
  150. package/lib/api/shared-contact-card.service.d.ts +33 -0
  151. package/lib/api/shared-contact-card2.gql.d.ts +36 -0
  152. package/lib/api/shared-contact-card2.service.d.ts +45 -0
  153. package/lib/api/time.service.d.ts +16 -0
  154. package/lib/api/types/graphql.types.d.ts +29 -0
  155. package/lib/api/types/index.d.ts +2 -0
  156. package/lib/api/types/lr-graphql.types.d.ts +385 -0
  157. package/lib/auth/auth.config.d.ts +5 -0
  158. package/lib/auth/auth.gql.d.ts +15 -0
  159. package/lib/auth/auth.types.d.ts +66 -0
  160. package/lib/auth/idle.service.d.ts +40 -0
  161. package/lib/auth/idle.types.d.ts +10 -0
  162. package/lib/auth/lbop.service.d.ts +91 -0
  163. package/lib/auth/life-ready-auth.service.d.ts +46 -0
  164. package/lib/auth/password.service.d.ts +78 -0
  165. package/lib/auth/register.service.d.ts +25 -0
  166. package/lib/auth/two-factor.service.d.ts +15 -0
  167. package/lib/category/category-meta.service.d.ts +23 -0
  168. package/lib/category/category.gql.d.ts +45 -0
  169. package/lib/category/category.service.d.ts +67 -0
  170. package/lib/category/category.types.d.ts +79 -0
  171. package/lib/cryptography/cryptography.types.d.ts +83 -0
  172. package/lib/cryptography/encryption.service.d.ts +41 -0
  173. package/lib/cryptography/key-factory.service.d.ts +38 -0
  174. package/lib/cryptography/key-graph.service.d.ts +33 -0
  175. package/lib/cryptography/key-meta.service.d.ts +44 -0
  176. package/lib/cryptography/key.service.d.ts +36 -0
  177. package/lib/cryptography/slip39.service.d.ts +43 -0
  178. package/lib/cryptography/web-crypto.service.d.ts +5 -0
  179. package/lib/life-ready.config.d.ts +14 -0
  180. package/lib/life-ready.module.d.ts +5 -0
  181. package/lib/plan/plan.gql.d.ts +11 -0
  182. package/lib/plan/plan.service.d.ts +33 -0
  183. package/lib/plan/plan.types.d.ts +31 -0
  184. package/lib/record/record-attachment.service.d.ts +16 -0
  185. package/lib/record/record.gql.d.ts +14 -0
  186. package/lib/record/record.service.d.ts +25 -0
  187. package/lib/record/record.types.d.ts +57 -0
  188. package/lib/record-type/record-type.service.d.ts +11 -0
  189. package/lib/record-type/record-type.types.d.ts +50 -0
  190. package/lib/scenario/approvals/scenario-approval.gql.d.ts +7 -0
  191. package/lib/scenario/approvals/scenario-approval.types.d.ts +63 -0
  192. package/lib/scenario/approvals/scenario-approver.service.d.ts +32 -0
  193. package/lib/scenario/claimants/scenario-claimant.gql.d.ts +5 -0
  194. package/lib/scenario/claimants/scenario-claimant.service.d.ts +17 -0
  195. package/lib/scenario/claimants/scenario-claimant.types.d.ts +18 -0
  196. package/lib/scenario/receivers/scenario-receiver.gql.d.ts +8 -0
  197. package/lib/scenario/receivers/scenario-receiver.service.d.ts +30 -0
  198. package/lib/scenario/receivers/scenario-receiver.types.d.ts +54 -0
  199. package/lib/scenario/scenario-setup.service.d.ts +22 -0
  200. package/lib/scenario/scenario.gql.d.ts +34 -0
  201. package/lib/scenario/scenario.service.d.ts +58 -0
  202. package/lib/scenario/scenario.types.d.ts +217 -0
  203. package/lib/search/search.gql.d.ts +1 -0
  204. package/lib/search/search.service.d.ts +25 -0
  205. package/lib/search/search.types.d.ts +20 -0
  206. package/lib/trusted-parties/tp-password-reset-request.service.d.ts +20 -0
  207. package/lib/trusted-parties/tp-password-reset-user.service.d.ts +41 -0
  208. package/lib/trusted-parties/tp-password-reset.gql.d.ts +218 -0
  209. package/lib/trusted-parties/tp-password-reset.service.d.ts +131 -0
  210. package/lib/trusted-parties/trusted-party.gql.d.ts +9 -0
  211. package/lib/trusted-parties/trusted-party.service.d.ts +44 -0
  212. package/lib/trusted-parties/trusted-party.types.d.ts +102 -0
  213. package/lib/trusted-parties/trusted-party2.gql.d.ts +79 -0
  214. package/lib/trusted-parties/trusted-party2.service.d.ts +114 -0
  215. package/lib/users/profile-details.service.d.ts +21 -0
  216. package/lib/users/profile.gql.d.ts +11 -0
  217. package/lib/users/profile.service.d.ts +35 -0
  218. package/lib/users/profile.types.d.ts +96 -0
  219. package/lib/users/user.gql.d.ts +9 -0
  220. package/lib/users/user.service.d.ts +12 -0
  221. package/lib/users/user.types.d.ts +23 -0
  222. package/lifeready-core.d.ts +9 -0
  223. package/lifeready-core.metadata.json +1 -0
  224. package/package.json +29 -0
  225. package/public-api.d.ts +77 -0
@@ -0,0 +1,74 @@
1
+ import { __awaiter } from "tslib";
2
+ import { Injectable } from '@angular/core';
3
+ import { AuthClass } from '@aws-amplify/auth/lib-esm/Auth';
4
+ import { LrBadArgumentException } from '../_common/exceptions';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@aws-amplify/auth/lib-esm/Auth";
7
+ export class TwoFactorService {
8
+ constructor(auth) {
9
+ this.auth = auth;
10
+ }
11
+ getPreferredMFA() {
12
+ return __awaiter(this, void 0, void 0, function* () {
13
+ const cognitoUser = yield this.auth.currentAuthenticatedUser();
14
+ return yield this.auth.getPreferredMFA(cognitoUser);
15
+ });
16
+ }
17
+ setPreferredMFA(method) {
18
+ return __awaiter(this, void 0, void 0, function* () {
19
+ const cognitoUser = yield this.auth.currentAuthenticatedUser();
20
+ yield this.auth.setPreferredMFA(cognitoUser, method);
21
+ });
22
+ }
23
+ setPhoneNumber(phone) {
24
+ return __awaiter(this, void 0, void 0, function* () {
25
+ const cognitoUser = yield this.auth.currentAuthenticatedUser();
26
+ yield this.auth.updateUserAttributes(cognitoUser, {
27
+ phone_number: phone,
28
+ });
29
+ });
30
+ }
31
+ getSMSCode() {
32
+ return __awaiter(this, void 0, void 0, function* () {
33
+ yield this.auth.verifyCurrentUserAttribute('phone_number');
34
+ });
35
+ }
36
+ verifySMSCode(verificationCode) {
37
+ return __awaiter(this, void 0, void 0, function* () {
38
+ yield this.auth.verifyCurrentUserAttributeSubmit('phone_number', verificationCode);
39
+ });
40
+ }
41
+ getSoftwareToken() {
42
+ return __awaiter(this, void 0, void 0, function* () {
43
+ const [cognitoUser, userInfo] = yield Promise.all([
44
+ this.auth.currentAuthenticatedUser(),
45
+ this.auth.currentUserInfo(),
46
+ ]);
47
+ const code = yield this.auth.setupTOTP(cognitoUser);
48
+ const email = userInfo.attributes.email;
49
+ if (!email) {
50
+ throw new LrBadArgumentException('No email associated with user.');
51
+ }
52
+ return {
53
+ code,
54
+ codeUri: `otpauth://totp/${email}?secret=${code}&issuer=LifeReady`,
55
+ };
56
+ });
57
+ }
58
+ verifySoftwareToken(totpCode) {
59
+ return __awaiter(this, void 0, void 0, function* () {
60
+ const cognitoUser = yield this.auth.currentAuthenticatedUser();
61
+ yield this.auth.verifyTotpToken(cognitoUser, totpCode);
62
+ });
63
+ }
64
+ }
65
+ TwoFactorService.ɵprov = i0.ɵɵdefineInjectable({ factory: function TwoFactorService_Factory() { return new TwoFactorService(i0.ɵɵinject(i1.AuthClass)); }, token: TwoFactorService, providedIn: "root" });
66
+ TwoFactorService.decorators = [
67
+ { type: Injectable, args: [{
68
+ providedIn: 'root',
69
+ },] }
70
+ ];
71
+ TwoFactorService.ctorParameters = () => [
72
+ { type: AuthClass }
73
+ ];
74
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHdvLWZhY3Rvci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IkM6L1Byb2plY3RzL3Rlc3QvcHJvamVjdHMvY29yZS9zcmMvIiwic291cmNlcyI6WyJsaWIvYXV0aC90d28tZmFjdG9yLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFM0MsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQzNELE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDOzs7QUFLL0QsTUFBTSxPQUFPLGdCQUFnQjtJQUMzQixZQUFvQixJQUFlO1FBQWYsU0FBSSxHQUFKLElBQUksQ0FBVztJQUFHLENBQUM7SUFFMUIsZUFBZTs7WUFDMUIsTUFBTSxXQUFXLEdBQWdCLE1BQU0sSUFBSSxDQUFDLElBQUksQ0FBQyx3QkFBd0IsRUFBRSxDQUFDO1lBRTVFLE9BQU8sTUFBTSxJQUFJLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUN0RCxDQUFDO0tBQUE7SUFFWSxlQUFlLENBQzFCLE1BQWdDOztZQUVoQyxNQUFNLFdBQVcsR0FBZ0IsTUFBTSxJQUFJLENBQUMsSUFBSSxDQUFDLHdCQUF3QixFQUFFLENBQUM7WUFFNUUsTUFBTSxJQUFJLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxXQUFXLEVBQUUsTUFBTSxDQUFDLENBQUM7UUFDdkQsQ0FBQztLQUFBO0lBRVksY0FBYyxDQUFDLEtBQUs7O1lBQy9CLE1BQU0sV0FBVyxHQUFnQixNQUFNLElBQUksQ0FBQyxJQUFJLENBQUMsd0JBQXdCLEVBQUUsQ0FBQztZQUU1RSxNQUFNLElBQUksQ0FBQyxJQUFJLENBQUMsb0JBQW9CLENBQUMsV0FBVyxFQUFFO2dCQUNoRCxZQUFZLEVBQUUsS0FBSzthQUNwQixDQUFDLENBQUM7UUFDTCxDQUFDO0tBQUE7SUFFWSxVQUFVOztZQUNyQixNQUFNLElBQUksQ0FBQyxJQUFJLENBQUMsMEJBQTBCLENBQUMsY0FBYyxDQUFDLENBQUM7UUFDN0QsQ0FBQztLQUFBO0lBRVksYUFBYSxDQUFDLGdCQUF3Qjs7WUFDakQsTUFBTSxJQUFJLENBQUMsSUFBSSxDQUFDLGdDQUFnQyxDQUM5QyxjQUFjLEVBQ2QsZ0JBQWdCLENBQ2pCLENBQUM7UUFDSixDQUFDO0tBQUE7SUFFWSxnQkFBZ0I7O1lBQzNCLE1BQU0sQ0FBQyxXQUFXLEVBQUUsUUFBUSxDQUFDLEdBQUcsTUFBTSxPQUFPLENBQUMsR0FBRyxDQUFDO2dCQUNoRCxJQUFJLENBQUMsSUFBSSxDQUFDLHdCQUF3QixFQUFFO2dCQUNwQyxJQUFJLENBQUMsSUFBSSxDQUFDLGVBQWUsRUFBRTthQUM1QixDQUFDLENBQUM7WUFFSCxNQUFNLElBQUksR0FBRyxNQUFNLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLFdBQVcsQ0FBQyxDQUFDO1lBRXBELE1BQU0sS0FBSyxHQUFHLFFBQVEsQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDO1lBQ3hDLElBQUksQ0FBQyxLQUFLLEVBQUU7Z0JBQ1YsTUFBTSxJQUFJLHNCQUFzQixDQUFDLGdDQUFnQyxDQUFDLENBQUM7YUFDcEU7WUFFRCxPQUFPO2dCQUNMLElBQUk7Z0JBQ0osT0FBTyxFQUFFLGtCQUFrQixLQUFLLFdBQVcsSUFBSSxtQkFBbUI7YUFDbkUsQ0FBQztRQUNKLENBQUM7S0FBQTtJQUVZLG1CQUFtQixDQUFDLFFBQWdCOztZQUMvQyxNQUFNLFdBQVcsR0FBZ0IsTUFBTSxJQUFJLENBQUMsSUFBSSxDQUFDLHdCQUF3QixFQUFFLENBQUM7WUFFNUUsTUFBTSxJQUFJLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxXQUFXLEVBQUUsUUFBUSxDQUFDLENBQUM7UUFDekQsQ0FBQztLQUFBOzs7O1lBOURGLFVBQVUsU0FBQztnQkFDVixVQUFVLEVBQUUsTUFBTTthQUNuQjs7O1lBTFEsU0FBUyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29nbml0b1VzZXIgfSBmcm9tICdAYXdzLWFtcGxpZnkvYXV0aCc7XHJcbmltcG9ydCB7IEF1dGhDbGFzcyB9IGZyb20gJ0Bhd3MtYW1wbGlmeS9hdXRoL2xpYi1lc20vQXV0aCc7XHJcbmltcG9ydCB7IExyQmFkQXJndW1lbnRFeGNlcHRpb24gfSBmcm9tICcuLi9fY29tbW9uL2V4Y2VwdGlvbnMnO1xyXG5cclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46ICdyb290JyxcclxufSlcclxuZXhwb3J0IGNsYXNzIFR3b0ZhY3RvclNlcnZpY2Uge1xyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgYXV0aDogQXV0aENsYXNzKSB7fVxyXG5cclxuICBwdWJsaWMgYXN5bmMgZ2V0UHJlZmVycmVkTUZBKCk6IFByb21pc2U8c3RyaW5nPiB7XHJcbiAgICBjb25zdCBjb2duaXRvVXNlcjogQ29nbml0b1VzZXIgPSBhd2FpdCB0aGlzLmF1dGguY3VycmVudEF1dGhlbnRpY2F0ZWRVc2VyKCk7XHJcblxyXG4gICAgcmV0dXJuIGF3YWl0IHRoaXMuYXV0aC5nZXRQcmVmZXJyZWRNRkEoY29nbml0b1VzZXIpO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGFzeW5jIHNldFByZWZlcnJlZE1GQShcclxuICAgIG1ldGhvZDogJ1RPVFAnIHwgJ1NNUycgfCAnTk9NRkEnXHJcbiAgKTogUHJvbWlzZTx2b2lkPiB7XHJcbiAgICBjb25zdCBjb2duaXRvVXNlcjogQ29nbml0b1VzZXIgPSBhd2FpdCB0aGlzLmF1dGguY3VycmVudEF1dGhlbnRpY2F0ZWRVc2VyKCk7XHJcblxyXG4gICAgYXdhaXQgdGhpcy5hdXRoLnNldFByZWZlcnJlZE1GQShjb2duaXRvVXNlciwgbWV0aG9kKTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBhc3luYyBzZXRQaG9uZU51bWJlcihwaG9uZSk6IFByb21pc2U8dm9pZD4ge1xyXG4gICAgY29uc3QgY29nbml0b1VzZXI6IENvZ25pdG9Vc2VyID0gYXdhaXQgdGhpcy5hdXRoLmN1cnJlbnRBdXRoZW50aWNhdGVkVXNlcigpO1xyXG5cclxuICAgIGF3YWl0IHRoaXMuYXV0aC51cGRhdGVVc2VyQXR0cmlidXRlcyhjb2duaXRvVXNlciwge1xyXG4gICAgICBwaG9uZV9udW1iZXI6IHBob25lLFxyXG4gICAgfSk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgYXN5bmMgZ2V0U01TQ29kZSgpIHtcclxuICAgIGF3YWl0IHRoaXMuYXV0aC52ZXJpZnlDdXJyZW50VXNlckF0dHJpYnV0ZSgncGhvbmVfbnVtYmVyJyk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgYXN5bmMgdmVyaWZ5U01TQ29kZSh2ZXJpZmljYXRpb25Db2RlOiBzdHJpbmcpIHtcclxuICAgIGF3YWl0IHRoaXMuYXV0aC52ZXJpZnlDdXJyZW50VXNlckF0dHJpYnV0ZVN1Ym1pdChcclxuICAgICAgJ3Bob25lX251bWJlcicsXHJcbiAgICAgIHZlcmlmaWNhdGlvbkNvZGVcclxuICAgICk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgYXN5bmMgZ2V0U29mdHdhcmVUb2tlbigpOiBQcm9taXNlPHsgY29kZTogc3RyaW5nOyBjb2RlVXJpOiBzdHJpbmcgfT4ge1xyXG4gICAgY29uc3QgW2NvZ25pdG9Vc2VyLCB1c2VySW5mb10gPSBhd2FpdCBQcm9taXNlLmFsbChbXHJcbiAgICAgIHRoaXMuYXV0aC5jdXJyZW50QXV0aGVudGljYXRlZFVzZXIoKSxcclxuICAgICAgdGhpcy5hdXRoLmN1cnJlbnRVc2VySW5mbygpLFxyXG4gICAgXSk7XHJcblxyXG4gICAgY29uc3QgY29kZSA9IGF3YWl0IHRoaXMuYXV0aC5zZXR1cFRPVFAoY29nbml0b1VzZXIpO1xyXG5cclxuICAgIGNvbnN0IGVtYWlsID0gdXNlckluZm8uYXR0cmlidXRlcy5lbWFpbDtcclxuICAgIGlmICghZW1haWwpIHtcclxuICAgICAgdGhyb3cgbmV3IExyQmFkQXJndW1lbnRFeGNlcHRpb24oJ05vIGVtYWlsIGFzc29jaWF0ZWQgd2l0aCB1c2VyLicpO1xyXG4gICAgfVxyXG5cclxuICAgIHJldHVybiB7XHJcbiAgICAgIGNvZGUsXHJcbiAgICAgIGNvZGVVcmk6IGBvdHBhdXRoOi8vdG90cC8ke2VtYWlsfT9zZWNyZXQ9JHtjb2RlfSZpc3N1ZXI9TGlmZVJlYWR5YCxcclxuICAgIH07XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgYXN5bmMgdmVyaWZ5U29mdHdhcmVUb2tlbih0b3RwQ29kZTogc3RyaW5nKTogUHJvbWlzZTx2b2lkPiB7XHJcbiAgICBjb25zdCBjb2duaXRvVXNlcjogQ29nbml0b1VzZXIgPSBhd2FpdCB0aGlzLmF1dGguY3VycmVudEF1dGhlbnRpY2F0ZWRVc2VyKCk7XHJcblxyXG4gICAgYXdhaXQgdGhpcy5hdXRoLnZlcmlmeVRvdHBUb2tlbihjb2duaXRvVXNlciwgdG90cENvZGUpO1xyXG4gIH1cclxufVxyXG4iXX0=
@@ -0,0 +1,99 @@
1
+ import { __awaiter } from "tslib";
2
+ import { HttpClient } from '@angular/common/http';
3
+ import { Injectable } from '@angular/core';
4
+ import { CategoryService } from './category.service';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@angular/common/http";
7
+ import * as i2 from "./category.service";
8
+ export class LoadedCategoryTree {
9
+ }
10
+ export class CategoryMetaService {
11
+ constructor(http, categoryService) {
12
+ this.http = http;
13
+ this.categoryService = categoryService;
14
+ }
15
+ getCoreCategories() {
16
+ return __awaiter(this, void 0, void 0, function* () {
17
+ if (!this.categories) {
18
+ this.categories = yield this.http
19
+ .get('/assets/meta/categories.json')
20
+ .toPromise();
21
+ }
22
+ return Promise.resolve(this.categories);
23
+ });
24
+ }
25
+ loadCategories(categoryTrees, selectedCategoryId, trustedPartyId) {
26
+ return __awaiter(this, void 0, void 0, function* () {
27
+ const rootCategories = trustedPartyId
28
+ ? (yield this.categoryService.getTrustedPartyCategories(trustedPartyId))
29
+ .categories
30
+ : yield this.categoryService.getCategories();
31
+ const selectedCategory = selectedCategoryId
32
+ ? yield this.categoryService.getCategory(selectedCategoryId)
33
+ : null;
34
+ const categoryPromises = categoryTrees.map((x) => __awaiter(this, void 0, void 0, function* () {
35
+ return ({
36
+ categoryTree: x,
37
+ category: yield this.loadCategory([...x], rootCategories, selectedCategory),
38
+ });
39
+ }));
40
+ const loadedCategories = yield Promise.all(categoryPromises);
41
+ const loadedCategoryTree = {
42
+ categories: [],
43
+ missingCategories: [],
44
+ };
45
+ loadedCategories.forEach((x) => x.category
46
+ ? loadedCategoryTree.categories.push(x.category)
47
+ : loadedCategoryTree.missingCategories.push(x.categoryTree));
48
+ return loadedCategoryTree;
49
+ });
50
+ }
51
+ loadCategoriesForRole(categories) {
52
+ return __awaiter(this, void 0, void 0, function* () {
53
+ const rootCategories = yield this.categoryService.getCategories();
54
+ return yield Promise.all(categories.map((x) => __awaiter(this, void 0, void 0, function* () {
55
+ return ({
56
+ category: yield this.loadCategory([...x.category], rootCategories),
57
+ accessLevel: x.accessLevel,
58
+ });
59
+ })));
60
+ });
61
+ }
62
+ loadCategory(categoryTree, categories, selectedCategory) {
63
+ return __awaiter(this, void 0, void 0, function* () {
64
+ const name = categoryTree.shift();
65
+ const currentCategory = categories.find((x) => x.code === name && !x.isCustom);
66
+ if (currentCategory) {
67
+ if (categoryTree.length) {
68
+ const { subCategories } = yield this.categoryService.getCategory(currentCategory.id);
69
+ return this.loadCategory(categoryTree, subCategories, selectedCategory);
70
+ }
71
+ else {
72
+ const { category } = yield this.categoryService.getCategory(currentCategory.id);
73
+ if (selectedCategory &&
74
+ selectedCategory.category.parents.some((x) => x.id === category.id)) {
75
+ return selectedCategory.category;
76
+ }
77
+ return category;
78
+ }
79
+ }
80
+ else if (categoryTree.length) {
81
+ return this.loadCategory(categoryTree, categories, selectedCategory);
82
+ }
83
+ else {
84
+ return null;
85
+ }
86
+ });
87
+ }
88
+ }
89
+ CategoryMetaService.ɵprov = i0.ɵɵdefineInjectable({ factory: function CategoryMetaService_Factory() { return new CategoryMetaService(i0.ɵɵinject(i1.HttpClient), i0.ɵɵinject(i2.CategoryService)); }, token: CategoryMetaService, providedIn: "root" });
90
+ CategoryMetaService.decorators = [
91
+ { type: Injectable, args: [{
92
+ providedIn: 'root',
93
+ },] }
94
+ ];
95
+ CategoryMetaService.ctorParameters = () => [
96
+ { type: HttpClient },
97
+ { type: CategoryService }
98
+ ];
99
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"category-meta.service.js","sourceRoot":"C:/Projects/test/projects/core/src/","sources":["lib/category/category-meta.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\r\nimport { Injectable } from '@angular/core';\r\nimport { CategoryService } from './category.service';\r\nimport {\r\n  AccessLevel,\r\n  Category,\r\n  CurrentCategory,\r\n  DefaultCategory,\r\n  VaultCategory,\r\n} from './category.types';\r\n\r\nexport class LoadedCategoryTree {\r\n  categories: CurrentCategory[];\r\n  missingCategories: string[][];\r\n}\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class CategoryMetaService {\r\n  private categories: DefaultCategory[];\r\n\r\n  constructor(\r\n    private http: HttpClient,\r\n    private categoryService: CategoryService\r\n  ) {}\r\n\r\n  public async getCoreCategories(): Promise<DefaultCategory[]> {\r\n    if (!this.categories) {\r\n      this.categories = await this.http\r\n        .get<DefaultCategory[]>('/assets/meta/categories.json')\r\n        .toPromise();\r\n    }\r\n    return Promise.resolve(this.categories);\r\n  }\r\n\r\n  async loadCategories(\r\n    categoryTrees: string[][],\r\n    selectedCategoryId?: string,\r\n    trustedPartyId?: string\r\n  ): Promise<LoadedCategoryTree> {\r\n    const rootCategories = trustedPartyId\r\n      ? (await this.categoryService.getTrustedPartyCategories(trustedPartyId))\r\n          .categories\r\n      : await this.categoryService.getCategories();\r\n\r\n    const selectedCategory = selectedCategoryId\r\n      ? await this.categoryService.getCategory(selectedCategoryId)\r\n      : null;\r\n\r\n    const categoryPromises = categoryTrees.map(async (x) => ({\r\n      categoryTree: x,\r\n      category: await this.loadCategory(\r\n        [...x],\r\n        rootCategories,\r\n        selectedCategory\r\n      ),\r\n    }));\r\n\r\n    const loadedCategories = await Promise.all(categoryPromises);\r\n\r\n    const loadedCategoryTree: LoadedCategoryTree = {\r\n      categories: [],\r\n      missingCategories: [],\r\n    };\r\n\r\n    loadedCategories.forEach((x) =>\r\n      x.category\r\n        ? loadedCategoryTree.categories.push(x.category)\r\n        : loadedCategoryTree.missingCategories.push(x.categoryTree)\r\n    );\r\n\r\n    return loadedCategoryTree;\r\n  }\r\n\r\n  async loadCategoriesForRole(\r\n    categories: { category: string[]; accessLevel: AccessLevel }[]\r\n  ): Promise<{ category: CurrentCategory; accessLevel: AccessLevel }[]> {\r\n    const rootCategories = await this.categoryService.getCategories();\r\n\r\n    return await Promise.all(\r\n      categories.map(async (x) => ({\r\n        category: await this.loadCategory([...x.category], rootCategories),\r\n        accessLevel: x.accessLevel,\r\n      }))\r\n    );\r\n  }\r\n\r\n  private async loadCategory(\r\n    categoryTree: string[],\r\n    categories: Category[],\r\n    selectedCategory?: VaultCategory\r\n  ): Promise<CurrentCategory> {\r\n    const name = categoryTree.shift();\r\n\r\n    const currentCategory = categories.find(\r\n      (x) => x.code === name && !x.isCustom\r\n    );\r\n\r\n    if (currentCategory) {\r\n      if (categoryTree.length) {\r\n        const { subCategories } = await this.categoryService.getCategory(\r\n          currentCategory.id\r\n        );\r\n        return this.loadCategory(categoryTree, subCategories, selectedCategory);\r\n      } else {\r\n        const { category } = await this.categoryService.getCategory(\r\n          currentCategory.id\r\n        );\r\n\r\n        if (\r\n          selectedCategory &&\r\n          selectedCategory.category.parents.some((x) => x.id === category.id)\r\n        ) {\r\n          return selectedCategory.category;\r\n        }\r\n        return category;\r\n      }\r\n    } else if (categoryTree.length) {\r\n      return this.loadCategory(categoryTree, categories, selectedCategory);\r\n    } else {\r\n      return null;\r\n    }\r\n  }\r\n}\r\n"]}
@@ -0,0 +1,406 @@
1
+ import { KeyGraphFragment } from '../_common/queries.gql';
2
+ import gql from 'graphql-tag';
3
+ export const DEFAULT_BREADCRUMB_DEPTH = 5;
4
+ export const DEFAULT_DESCENDANTS_DEPTH = 5;
5
+ export var DirectoryType;
6
+ (function (DirectoryType) {
7
+ DirectoryType["Vault"] = "vault";
8
+ DirectoryType["Category"] = "category";
9
+ DirectoryType["Record"] = "record";
10
+ })(DirectoryType || (DirectoryType = {}));
11
+ export const DefaultVaultFilter = JSON.stringify({
12
+ filter: [
13
+ {
14
+ contains: {
15
+ directoryType: DirectoryType.Vault,
16
+ default: true,
17
+ },
18
+ },
19
+ ],
20
+ });
21
+ export const CategoryFilter = JSON.stringify({
22
+ filter: [
23
+ {
24
+ contains: {
25
+ directoryType: DirectoryType.Category,
26
+ },
27
+ },
28
+ ],
29
+ });
30
+ export const RecordFilter = JSON.stringify({
31
+ filter: [
32
+ {
33
+ contains: {
34
+ directoryType: DirectoryType.Record,
35
+ },
36
+ },
37
+ ],
38
+ });
39
+ export const AccessFields = `
40
+ accessRoles {
41
+ role
42
+ method
43
+ inheritedFrom {
44
+ id
45
+ }
46
+ trustedParty {
47
+ id
48
+ }
49
+ isIssuer
50
+ }`;
51
+ const descendantDirectories = `
52
+ descendantDirectories(depth: ${DEFAULT_DESCENDANTS_DEPTH}, plainMeta: $categoryFilter, archived: false) {
53
+ recordsCount: directoriesCount(plainMeta: $recordFilter, archived: false)
54
+ }
55
+ `;
56
+ export const CategoryFields = `
57
+ id
58
+ keyId
59
+ archived
60
+ plainMeta
61
+ cipherMeta
62
+ ${AccessFields}
63
+ ${descendantDirectories}
64
+ `;
65
+ export const VaultFields = `
66
+ id
67
+ keyId
68
+ plainMeta
69
+ cipherMeta
70
+ `;
71
+ export const GetRootDirectoryIdsQuery = gql `
72
+ query GetRootDirectoryIdsQuery($archived: Boolean) {
73
+ rootDirectories(archived: $archived) {
74
+ edges {
75
+ node {
76
+ id
77
+ }
78
+ }
79
+ }
80
+ }
81
+ `;
82
+ export const GetCategoriesQuery = gql `
83
+ query GetCategories($vaultFilter: LrJSONFilter!, $categoryFilter: LrJSONFilter!, $recordFilter: LrJSONFilter!, $archived: Boolean, $cachedKeyIds: [LrRelayIdInput!])
84
+ {
85
+ vaults: rootDirectories(plainMeta: $vaultFilter) {
86
+ edges {
87
+ node {
88
+ childDirectoryLinks(plainMeta: $categoryFilter, orderBy: "created", archived: $archived) {
89
+ edges {
90
+ node {
91
+ childDirectory {
92
+ ${CategoryFields}
93
+ }
94
+ }
95
+ }
96
+ }
97
+ }
98
+ }
99
+ }
100
+ keyGraph(cachedKeyIds: $cachedKeyIds) {
101
+ ...KeyGraphFragment
102
+ }
103
+ }
104
+ ${KeyGraphFragment}
105
+ `;
106
+ export const GetVaultsQuery = gql `
107
+ query GetVaults($plainMetaFilter: LrJSONFilter!, $cachedKeyIds: [LrRelayIdInput!])
108
+ {
109
+ list: rootDirectories(plainMeta: $plainMetaFilter, orderBy: "created") {
110
+ edges {
111
+ node {
112
+ ${VaultFields}
113
+ }
114
+ }
115
+ }
116
+ keyGraph(cachedKeyIds: $cachedKeyIds) {
117
+ ...KeyGraphFragment
118
+ }
119
+ }
120
+ ${KeyGraphFragment}
121
+ `;
122
+ export const GetTrustedPartyCategoriesQuery = gql `
123
+ query GetTrustedPartyCategoriesQuery($trustedPartyId: LrRelayIdInput!, $categoryFilter: LrJSONFilter!, $recordFilter: LrJSONFilter!, $contentFilter: LrJSONFilter, $cachedKeyIds: [LrRelayIdInput!])
124
+ {
125
+ tp(id: $trustedPartyId) {
126
+ sharedItems {
127
+ list: directories(plainMeta: $categoryFilter, orderBy: "created") {
128
+ edges {
129
+ node {
130
+ ${CategoryFields}
131
+ }
132
+ }
133
+ }
134
+ records: directories(plainMeta: $recordFilter, orderBy: "created") {
135
+ edges {
136
+ node {
137
+ id
138
+ keyId
139
+ archived
140
+ plainMeta
141
+ cipherMeta
142
+ created
143
+ modified
144
+ ${AccessFields}
145
+ content: childFileLinks(plainMeta: $contentFilter) {
146
+ edges {
147
+ node {
148
+ childFile {
149
+ id
150
+ archived
151
+ currentVersion {
152
+ state {
153
+ keyId
154
+ plainMeta
155
+ cipherMeta
156
+ created
157
+ modified
158
+ }
159
+ }
160
+ }
161
+ }
162
+ }
163
+ }
164
+ }
165
+ }
166
+ }
167
+ }
168
+ }
169
+ keyGraph(cachedKeyIds: $cachedKeyIds) {
170
+ ...KeyGraphFragment
171
+ }
172
+ }
173
+ ${KeyGraphFragment}
174
+ `;
175
+ export const GetMySharedCategoriesQuery = gql `
176
+ query GetMySharedCategoriesQuery($trustedPartyId: LrRelayIdInput!, $categoryFilter: LrJSONFilter!, $recordFilter: LrJSONFilter!, $contentFilter: LrJSONFilter, $cachedKeyIds: [LrRelayIdInput!])
177
+ {
178
+ tp(id: $trustedPartyId) {
179
+ myItems {
180
+ list: directories(plainMeta: $categoryFilter, orderBy: "created") {
181
+ edges {
182
+ node {
183
+ ${CategoryFields}
184
+ }
185
+ }
186
+ }
187
+ records: directories(plainMeta: $recordFilter, orderBy: "created") {
188
+ edges {
189
+ node {
190
+ id
191
+ keyId
192
+ archived
193
+ plainMeta
194
+ cipherMeta
195
+ created
196
+ modified
197
+ ${AccessFields}
198
+ content: childFileLinks(plainMeta: $contentFilter) {
199
+ edges {
200
+ node {
201
+ childFile {
202
+ id
203
+ archived
204
+ currentVersion {
205
+ state {
206
+ keyId
207
+ plainMeta
208
+ cipherMeta
209
+ created
210
+ modified
211
+ }
212
+ }
213
+ }
214
+ }
215
+ }
216
+ }
217
+ }
218
+ }
219
+ }
220
+ }
221
+ }
222
+ keyGraph(cachedKeyIds: $cachedKeyIds) {
223
+ ...KeyGraphFragment
224
+ }
225
+ }
226
+ ${KeyGraphFragment}
227
+ `;
228
+ export const parentCategoriesField = (depth = DEFAULT_BREADCRUMB_DEPTH) => {
229
+ if (!depth) {
230
+ return '';
231
+ }
232
+ return `
233
+ parentCategories: parentDirectoryLinks(plainMeta: $categoryFilter) {
234
+ edges {
235
+ node {
236
+ parentDirectory {
237
+ id
238
+ keyId
239
+ archived
240
+ plainMeta
241
+ cipherMeta
242
+ ${parentCategoriesField(depth - 1)}
243
+ ${AccessFields}
244
+ }
245
+ }
246
+ }
247
+ }
248
+ `;
249
+ };
250
+ export const GetCategoryQuery = (depth = DEFAULT_BREADCRUMB_DEPTH) => gql `
251
+ query GetCategory(
252
+ $id: LrRelayIdInput!,
253
+ $categoryFilter: LrJSONFilter!,
254
+ $recordFilter: LrJSONFilter!,
255
+ $contentFilter: LrJSONFilter,
256
+ $cachedKeyIds: [LrRelayIdInput!]) {
257
+ category: directory(id: $id) {
258
+ id
259
+ keyId
260
+ archived
261
+ plainMeta
262
+ cipherMeta
263
+ ${AccessFields}
264
+ ${descendantDirectories}
265
+ ${parentCategoriesField(depth)}
266
+ subCategories: childDirectoryLinks(plainMeta: $categoryFilter, orderBy: "created") {
267
+ edges {
268
+ node {
269
+ childDirectory {
270
+ ${CategoryFields}
271
+ }
272
+ }
273
+ }
274
+ }
275
+ records: childDirectoryLinks(plainMeta: $recordFilter, orderBy: "created") {
276
+ edges {
277
+ node {
278
+ childDirectory {
279
+ id
280
+ keyId
281
+ archived
282
+ plainMeta
283
+ cipherMeta
284
+ created
285
+ modified
286
+ ${AccessFields}
287
+ content: childFileLinks(plainMeta: $contentFilter) {
288
+ edges {
289
+ node {
290
+ childFile {
291
+ id
292
+ archived
293
+ currentVersion {
294
+ state {
295
+ keyId
296
+ plainMeta
297
+ cipherMeta
298
+ created
299
+ modified
300
+ }
301
+ }
302
+ }
303
+ }
304
+ }
305
+ }
306
+ }
307
+ }
308
+ }
309
+ }
310
+ }
311
+ keyGraph(cachedKeyIds: $cachedKeyIds) {
312
+ ...KeyGraphFragment
313
+ }
314
+ }
315
+ ${KeyGraphFragment} `;
316
+ export const GetCategoryKeyIdQuery = gql `
317
+ query GetCategoryKeyIdQuery(
318
+ $id: LrRelayIdInput!
319
+ $cachedKeyIds: [LrRelayIdInput!]
320
+ ) {
321
+ category: directory(id: $id) {
322
+ keyId
323
+ }
324
+ keyGraph(cachedKeyIds: $cachedKeyIds) {
325
+ ...KeyGraphFragment
326
+ }
327
+ }
328
+ ${KeyGraphFragment}
329
+ `;
330
+ export const CreateCategoryMutation = gql `
331
+ mutation CreateCategory(
332
+ $plainMeta: LrJSONString
333
+ $cipherMeta: String
334
+ $parentDirectories: [ParentDirectoryInput!]
335
+ $parentRootDirectory: ParentRootDirectoryInput
336
+ ) {
337
+ new: createDirectory(
338
+ input: {
339
+ plainMeta: $plainMeta
340
+ cipherMeta: $cipherMeta
341
+ parentDirectories: $parentDirectories
342
+ parentRootDirectory: $parentRootDirectory
343
+ }
344
+ ) {
345
+ category: directory {
346
+ id
347
+ keyId
348
+ }
349
+ }
350
+ }
351
+ `;
352
+ export const CreateVaultMutation = gql `
353
+ mutation CreateCategory(
354
+ $plainMeta: LrJSONString
355
+ $cipherMeta: String
356
+ $parentRootDirectory: ParentRootDirectoryInput
357
+ ) {
358
+ new: createDirectory(
359
+ input: {
360
+ plainMeta: $plainMeta
361
+ cipherMeta: $cipherMeta
362
+ parentRootDirectory: $parentRootDirectory
363
+ }
364
+ ) {
365
+ vault: directory {
366
+ id
367
+ keyId
368
+ }
369
+ }
370
+ }
371
+ `;
372
+ export const UpdateCategoryMutation = gql `
373
+ mutation UpdateCategory($input: UpdateDirectoryInput!) {
374
+ updateDirectory(input: $input) {
375
+ directory {
376
+ id
377
+ }
378
+ }
379
+ }
380
+ `;
381
+ export const DeleteCategoryMutation = gql `
382
+ mutation DeleteCategory($categoryId: LrRelayIdInput!) {
383
+ deleteDirectory(input: { directoryId: $categoryId }) {
384
+ id
385
+ }
386
+ }
387
+ `;
388
+ export const ArchiveDirectoryMutation = gql `
389
+ mutation ArchiveDirectory($input: ArchiveDirectoryInput!) {
390
+ archiveDirectory(input: $input) {
391
+ directory {
392
+ id
393
+ }
394
+ }
395
+ }
396
+ `;
397
+ export const UnarchiveDirectoryMutation = gql `
398
+ mutation UnarchiveDirectory($input: UnarchiveDirectoryInput!) {
399
+ unarchiveDirectory(input: $input) {
400
+ directory {
401
+ id
402
+ }
403
+ }
404
+ }
405
+ `;
406
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"category.gql.js","sourceRoot":"C:/Projects/test/projects/core/src/","sources":["lib/category/category.gql.ts"],"names":[],"mappings":"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","sourcesContent":["import { HasKeyGraph } from './../cryptography/cryptography.types';\r\nimport { KeyGraphFragment } from '../_common/queries.gql';\r\nimport gql from 'graphql-tag';\r\nimport { HasKeyGraphEdges, HasEdges } from '../_common/types';\r\n\r\nexport const DEFAULT_BREADCRUMB_DEPTH = 5;\r\nexport const DEFAULT_DESCENDANTS_DEPTH = 5;\r\n\r\nexport enum DirectoryType {\r\n  Vault = 'vault',\r\n  Category = 'category',\r\n  Record = 'record',\r\n}\r\n\r\nexport const DefaultVaultFilter = JSON.stringify({\r\n  filter: [\r\n    {\r\n      contains: {\r\n        directoryType: DirectoryType.Vault,\r\n        default: true,\r\n      },\r\n    },\r\n  ],\r\n});\r\n\r\nexport const CategoryFilter = JSON.stringify({\r\n  filter: [\r\n    {\r\n      contains: {\r\n        directoryType: DirectoryType.Category,\r\n      },\r\n    },\r\n  ],\r\n});\r\n\r\nexport const RecordFilter = JSON.stringify({\r\n  filter: [\r\n    {\r\n      contains: {\r\n        directoryType: DirectoryType.Record,\r\n      },\r\n    },\r\n  ],\r\n});\r\n\r\nexport const AccessFields = `\r\naccessRoles {\r\n  role\r\n  method\r\n  inheritedFrom {\r\n    id\r\n  }\r\n  trustedParty {\r\n    id\r\n  }\r\n  isIssuer\r\n}`;\r\n\r\nconst descendantDirectories = `\r\ndescendantDirectories(depth: ${DEFAULT_DESCENDANTS_DEPTH}, plainMeta: $categoryFilter, archived: false) {\r\n  recordsCount: directoriesCount(plainMeta: $recordFilter, archived: false)\r\n}\r\n`;\r\n\r\nexport const CategoryFields = `\r\n  id\r\n  keyId\r\n  archived\r\n  plainMeta\r\n  cipherMeta\r\n  ${AccessFields}\r\n  ${descendantDirectories}\r\n`;\r\n\r\nexport const VaultFields = `\r\n  id\r\n  keyId\r\n  plainMeta\r\n  cipherMeta\r\n`;\r\n\r\nexport const GetRootDirectoryIdsQuery = gql`\r\n  query GetRootDirectoryIdsQuery($archived: Boolean) {\r\n    rootDirectories(archived: $archived) {\r\n      edges {\r\n        node {\r\n          id\r\n        }\r\n      }\r\n    }\r\n  }\r\n`;\r\n\r\nexport const GetCategoriesQuery = gql`\r\nquery GetCategories($vaultFilter: LrJSONFilter!, $categoryFilter: LrJSONFilter!, $recordFilter: LrJSONFilter!, $archived: Boolean, $cachedKeyIds: [LrRelayIdInput!])\r\n{\r\n  vaults: rootDirectories(plainMeta: $vaultFilter) {\r\n    edges {\r\n      node {\r\n        childDirectoryLinks(plainMeta: $categoryFilter, orderBy: \"created\", archived: $archived) {\r\n          edges {\r\n            node {\r\n              childDirectory {\r\n                ${CategoryFields}\r\n              }\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n  keyGraph(cachedKeyIds: $cachedKeyIds) {\r\n    ...KeyGraphFragment\r\n  }\r\n}\r\n${KeyGraphFragment}\r\n`;\r\n\r\nexport const GetVaultsQuery = gql`\r\nquery GetVaults($plainMetaFilter: LrJSONFilter!, $cachedKeyIds: [LrRelayIdInput!])\r\n{\r\n  list: rootDirectories(plainMeta: $plainMetaFilter, orderBy: \"created\") {\r\n    edges {\r\n      node {\r\n        ${VaultFields}\r\n      }\r\n    }\r\n  }\r\n  keyGraph(cachedKeyIds: $cachedKeyIds) {\r\n    ...KeyGraphFragment\r\n  }\r\n}\r\n${KeyGraphFragment}\r\n`;\r\n\r\nexport interface GetTrustedPartyCategoriesQueryType extends HasKeyGraph {\r\n  tp: {\r\n    sharedItems: {\r\n      list: HasEdges<any>;\r\n      records: HasEdges<any>;\r\n    };\r\n  };\r\n}\r\n\r\nexport const GetTrustedPartyCategoriesQuery = gql`\r\nquery GetTrustedPartyCategoriesQuery($trustedPartyId: LrRelayIdInput!, $categoryFilter: LrJSONFilter!, $recordFilter: LrJSONFilter!, $contentFilter: LrJSONFilter, $cachedKeyIds: [LrRelayIdInput!])\r\n{\r\n  tp(id: $trustedPartyId) {\r\n    sharedItems {\r\n      list: directories(plainMeta: $categoryFilter, orderBy: \"created\") {\r\n        edges {\r\n          node {\r\n            ${CategoryFields}\r\n          }\r\n        }\r\n      }\r\n      records: directories(plainMeta: $recordFilter, orderBy: \"created\") {\r\n        edges {\r\n          node {\r\n            id\r\n            keyId\r\n            archived\r\n            plainMeta\r\n            cipherMeta\r\n            created\r\n            modified\r\n            ${AccessFields}\r\n            content: childFileLinks(plainMeta: $contentFilter) {\r\n              edges {\r\n                node {\r\n                  childFile {\r\n                    id\r\n                    archived\r\n                    currentVersion {\r\n                      state {\r\n                        keyId\r\n                        plainMeta\r\n                        cipherMeta\r\n                        created\r\n                        modified\r\n                      }\r\n                    }\r\n                  }\r\n                }\r\n              }\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n  keyGraph(cachedKeyIds: $cachedKeyIds) {\r\n    ...KeyGraphFragment\r\n  }\r\n}\r\n${KeyGraphFragment}\r\n`;\r\n\r\nexport interface GetMySharedCategoriesQueryType extends HasKeyGraph {\r\n  tp: {\r\n    myItems: {\r\n      list: HasEdges<any>;\r\n      records: HasEdges<any>;\r\n    };\r\n  };\r\n}\r\n\r\nexport const GetMySharedCategoriesQuery = gql`\r\nquery GetMySharedCategoriesQuery($trustedPartyId: LrRelayIdInput!, $categoryFilter: LrJSONFilter!, $recordFilter: LrJSONFilter!, $contentFilter: LrJSONFilter, $cachedKeyIds: [LrRelayIdInput!])\r\n{\r\n  tp(id: $trustedPartyId) {\r\n    myItems {\r\n      list: directories(plainMeta: $categoryFilter, orderBy: \"created\") {\r\n        edges {\r\n          node {\r\n            ${CategoryFields}\r\n          }\r\n        }\r\n      }\r\n      records: directories(plainMeta: $recordFilter, orderBy: \"created\") {\r\n        edges {\r\n          node {\r\n            id\r\n            keyId\r\n            archived\r\n            plainMeta\r\n            cipherMeta\r\n            created\r\n            modified\r\n            ${AccessFields}\r\n            content: childFileLinks(plainMeta: $contentFilter) {\r\n              edges {\r\n                node {\r\n                  childFile {\r\n                    id\r\n                    archived\r\n                    currentVersion {\r\n                      state {\r\n                        keyId\r\n                        plainMeta\r\n                        cipherMeta\r\n                        created\r\n                        modified\r\n                      }\r\n                    }\r\n                  }\r\n                }\r\n              }\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n  keyGraph(cachedKeyIds: $cachedKeyIds) {\r\n    ...KeyGraphFragment\r\n  }\r\n}\r\n${KeyGraphFragment}\r\n`;\r\n\r\nexport const parentCategoriesField = (depth = DEFAULT_BREADCRUMB_DEPTH) => {\r\n  if (!depth) {\r\n    return '';\r\n  }\r\n  return `\r\nparentCategories: parentDirectoryLinks(plainMeta: $categoryFilter) {\r\n  edges {\r\n    node {\r\n      parentDirectory {\r\n        id\r\n        keyId\r\n        archived\r\n        plainMeta\r\n        cipherMeta\r\n        ${parentCategoriesField(depth - 1)}\r\n        ${AccessFields}\r\n      }\r\n    }\r\n  }\r\n}\r\n`;\r\n};\r\n\r\nexport const GetCategoryQuery = (\r\n  depth: number = DEFAULT_BREADCRUMB_DEPTH\r\n) => gql`\r\nquery GetCategory(\r\n  $id: LrRelayIdInput!,\r\n  $categoryFilter: LrJSONFilter!,\r\n  $recordFilter: LrJSONFilter!,\r\n  $contentFilter: LrJSONFilter,\r\n  $cachedKeyIds: [LrRelayIdInput!]) {\r\n  category: directory(id: $id) {\r\n    id\r\n    keyId\r\n    archived\r\n    plainMeta\r\n    cipherMeta\r\n    ${AccessFields}\r\n    ${descendantDirectories}\r\n    ${parentCategoriesField(depth)}\r\n    subCategories: childDirectoryLinks(plainMeta: $categoryFilter, orderBy: \"created\") {\r\n      edges {\r\n        node {\r\n          childDirectory {\r\n            ${CategoryFields}\r\n          }\r\n        }\r\n      }\r\n    }\r\n    records: childDirectoryLinks(plainMeta: $recordFilter, orderBy: \"created\") {\r\n      edges {\r\n        node {\r\n          childDirectory {\r\n            id\r\n            keyId\r\n            archived\r\n            plainMeta\r\n            cipherMeta\r\n            created\r\n            modified\r\n            ${AccessFields}\r\n            content: childFileLinks(plainMeta: $contentFilter) {\r\n              edges {\r\n                node {\r\n                  childFile {\r\n                    id\r\n                    archived\r\n                    currentVersion {\r\n                      state {\r\n                        keyId\r\n                        plainMeta\r\n                        cipherMeta\r\n                        created\r\n                        modified\r\n                      }\r\n                    }\r\n                  }\r\n                }\r\n              }\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n  keyGraph(cachedKeyIds: $cachedKeyIds) {\r\n    ...KeyGraphFragment\r\n  }\r\n}\r\n${KeyGraphFragment} `;\r\n\r\nexport const GetCategoryKeyIdQuery = gql`\r\n  query GetCategoryKeyIdQuery(\r\n    $id: LrRelayIdInput!\r\n    $cachedKeyIds: [LrRelayIdInput!]\r\n  ) {\r\n    category: directory(id: $id) {\r\n      keyId\r\n    }\r\n    keyGraph(cachedKeyIds: $cachedKeyIds) {\r\n      ...KeyGraphFragment\r\n    }\r\n  }\r\n  ${KeyGraphFragment}\r\n`;\r\n\r\nexport const CreateCategoryMutation = gql`\r\n  mutation CreateCategory(\r\n    $plainMeta: LrJSONString\r\n    $cipherMeta: String\r\n    $parentDirectories: [ParentDirectoryInput!]\r\n    $parentRootDirectory: ParentRootDirectoryInput\r\n  ) {\r\n    new: createDirectory(\r\n      input: {\r\n        plainMeta: $plainMeta\r\n        cipherMeta: $cipherMeta\r\n        parentDirectories: $parentDirectories\r\n        parentRootDirectory: $parentRootDirectory\r\n      }\r\n    ) {\r\n      category: directory {\r\n        id\r\n        keyId\r\n      }\r\n    }\r\n  }\r\n`;\r\n\r\nexport const CreateVaultMutation = gql`\r\n  mutation CreateCategory(\r\n    $plainMeta: LrJSONString\r\n    $cipherMeta: String\r\n    $parentRootDirectory: ParentRootDirectoryInput\r\n  ) {\r\n    new: createDirectory(\r\n      input: {\r\n        plainMeta: $plainMeta\r\n        cipherMeta: $cipherMeta\r\n        parentRootDirectory: $parentRootDirectory\r\n      }\r\n    ) {\r\n      vault: directory {\r\n        id\r\n        keyId\r\n      }\r\n    }\r\n  }\r\n`;\r\n\r\nexport const UpdateCategoryMutation = gql`\r\n  mutation UpdateCategory($input: UpdateDirectoryInput!) {\r\n    updateDirectory(input: $input) {\r\n      directory {\r\n        id\r\n      }\r\n    }\r\n  }\r\n`;\r\n\r\nexport const DeleteCategoryMutation = gql`\r\n  mutation DeleteCategory($categoryId: LrRelayIdInput!) {\r\n    deleteDirectory(input: { directoryId: $categoryId }) {\r\n      id\r\n    }\r\n  }\r\n`;\r\n\r\nexport const ArchiveDirectoryMutation = gql`\r\n  mutation ArchiveDirectory($input: ArchiveDirectoryInput!) {\r\n    archiveDirectory(input: $input) {\r\n      directory {\r\n        id\r\n      }\r\n    }\r\n  }\r\n`;\r\n\r\nexport const UnarchiveDirectoryMutation = gql`\r\n  mutation UnarchiveDirectory($input: UnarchiveDirectoryInput!) {\r\n    unarchiveDirectory(input: $input) {\r\n      directory {\r\n        id\r\n      }\r\n    }\r\n  }\r\n`;\r\n"]}