@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,192 @@
1
+ import { __awaiter, __decorate } from "tslib";
2
+ import { Injectable, NgZone } from '@angular/core';
3
+ import { LrBadLogicException } from '../../_common/exceptions';
4
+ import { mapValuesMayAsync, promiseAllMayAsync } from '../../_common/utils';
5
+ import { KeyService } from '../../cryptography/key.service';
6
+ import { CommonProcessorsService, DefaultProcessorOptions, } from './common-processors.service';
7
+ import { RunOutsideAngular } from '../../_common/run-outside-angular';
8
+ import { TpPasswordResetProcessorService } from './tp-password-reset-processor.service';
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "../../cryptography/key.service";
11
+ import * as i2 from "./common-processors.service";
12
+ import * as i3 from "./tp-password-reset-processor.service";
13
+ function extendPath(context, key) {
14
+ return Object.assign(Object.assign({}, context), { path: [...context.path, key] });
15
+ }
16
+ let QueryProcessorService = class QueryProcessorService {
17
+ constructor(ngZone, keyService, common, tpprProcessor) {
18
+ this.ngZone = ngZone;
19
+ this.keyService = keyService;
20
+ this.common = common;
21
+ this.tpprProcessor = tpprProcessor;
22
+ this.TYPENAME = '__typename';
23
+ this.processors = {};
24
+ this.registerProcessor('DirectoryNode', common.series([
25
+ common.makeJsonParseProcessor({
26
+ plainFieldName: 'plainMeta',
27
+ }),
28
+ common.makeDecryptionProcessor({
29
+ cipherFieldName: 'cipherMeta',
30
+ }),
31
+ ]));
32
+ this.registerProcessor('FileStateNode', common.series([
33
+ common.makeJsonParseProcessor({
34
+ plainFieldName: 'plainMeta',
35
+ }),
36
+ common.makeDecryptionProcessor({
37
+ cipherFieldName: 'cipherMeta',
38
+ }),
39
+ ]));
40
+ this.registerProcessor('ContactCardNode', common.makeDecryptionProcessor({
41
+ cipherFieldName: 'cipherData',
42
+ }));
43
+ this.registerProcessor('SharedContactCardNode', common.series([
44
+ common.makeJsonParseProcessor({
45
+ plainFieldName: 'ownerPlainData',
46
+ }),
47
+ common.makeDecryptionProcessor({
48
+ cipherFieldName: 'ownerCipherData',
49
+ getKeyId: ({ field }) => {
50
+ return field.ownerKey.id;
51
+ },
52
+ }),
53
+ common.makeDecryptionProcessor({
54
+ cipherFieldName: 'receiverCipherData',
55
+ getKeyId: ({ field }) => {
56
+ return field.receiverKey.id;
57
+ },
58
+ }),
59
+ common.makeDecryptionProcessor({
60
+ cipherFieldName: 'sharedCipherData',
61
+ getKeyId: ({ field }) => field.sharedKey.id,
62
+ }),
63
+ ]));
64
+ this.registerProcessor('TpPasswordResetNode', this.tpprProcessor.makeTpPasswordResetNodeProcessor());
65
+ this.registerProcessor('SharedTpClaimApproverNode', common.series([
66
+ common.makeDecryptionProcessor({
67
+ cipherFieldName: 'sharedCipherApprovalData',
68
+ getKeyId: ({ field }) => field.sharedKey.id,
69
+ }),
70
+ common.makeDecryptionProcessor({
71
+ cipherFieldName: 'sharedCipherPartialAssemblyKey',
72
+ getKeyId: ({ field }) => field.sharedKey.id,
73
+ }),
74
+ ]));
75
+ this.registerProcessor('TpAssemblyAsApproverNode', common.series([
76
+ common.makeDecryptionProcessor({
77
+ cipherFieldName: 'sharedCipherData',
78
+ getKeyId: ({ field }) => field.sharedKey.id,
79
+ }),
80
+ ]));
81
+ }
82
+ processQuery(fields, options) {
83
+ return __awaiter(this, void 0, void 0, function* () {
84
+ options = Object.assign(Object.assign({}, DefaultProcessorOptions), options);
85
+ // The top level query does not have __typename
86
+ const ret = mapValuesMayAsync(fields, (field, key) => this.processField({
87
+ field,
88
+ context: {
89
+ path: [key],
90
+ processChildren: true,
91
+ },
92
+ options,
93
+ }));
94
+ return ret;
95
+ });
96
+ }
97
+ // Either returns a Promise, or a value.
98
+ // The Promise<any> type is redundant but it shows that it can return a promise
99
+ // We are not using async on the function because we don't want auto promotion into a Promise, which
100
+ // always defer execution into the event loops. It is costly and unnecessary for objects
101
+ // with only native data types.
102
+ processField({ field, context, options, }) {
103
+ return __awaiter(this, void 0, void 0, function* () {
104
+ if (field === null || field === void 0 ? void 0 : field.then) {
105
+ throw new LrBadLogicException('processField() should not receive thenable.');
106
+ }
107
+ if (field == null) {
108
+ return null;
109
+ }
110
+ const newParams = {
111
+ field,
112
+ context: Object.assign(Object.assign({}, context), {
113
+ // Processors modifies this field to communicate back to the caller.
114
+ processChildren: true }),
115
+ options,
116
+ };
117
+ // TODO allow registering processors by field name so we can process primitive fields as well.
118
+ // We have common fields like "created", "modified" that be processed based on name.
119
+ if (field[this.TYPENAME]) {
120
+ // It's a custom object type
121
+ const processor = this.processors[field[this.TYPENAME]];
122
+ if (processor) {
123
+ // Returns either a value or a promise.
124
+ field = processor(newParams);
125
+ }
126
+ const processChildren = (childField) => {
127
+ if (context.processChildren &&
128
+ childField !== null &&
129
+ typeof childField === 'object') {
130
+ return mapValuesMayAsync(childField, (x, key) => this.processField({
131
+ field: x,
132
+ context: extendPath(context, key),
133
+ options,
134
+ }));
135
+ }
136
+ else {
137
+ return childField;
138
+ }
139
+ };
140
+ // Keep processing all child fields
141
+ if (field.then) {
142
+ // Wait for field to resolve
143
+ field = field.then((resolvedField) => {
144
+ return processChildren(resolvedField);
145
+ });
146
+ }
147
+ else {
148
+ // Field is already resolved
149
+ field = processChildren(field);
150
+ }
151
+ }
152
+ else {
153
+ // Keep processing all child fields
154
+ if (context.processChildren) {
155
+ if (Array.isArray(field)) {
156
+ field = promiseAllMayAsync(field.map((x, i) => this.processField({
157
+ field: x,
158
+ context: extendPath(context, i.toString()),
159
+ options,
160
+ })));
161
+ }
162
+ }
163
+ }
164
+ return field;
165
+ });
166
+ }
167
+ registerProcessor(name, processor) {
168
+ if (this.processors[name]) {
169
+ throw new LrBadLogicException(`Processor for field ${name} already exists.`);
170
+ }
171
+ this.processors[name] = processor;
172
+ }
173
+ };
174
+ QueryProcessorService.ɵprov = i0.ɵɵdefineInjectable({ factory: function QueryProcessorService_Factory() { return new QueryProcessorService(i0.ɵɵinject(i0.NgZone), i0.ɵɵinject(i1.KeyService), i0.ɵɵinject(i2.CommonProcessorsService), i0.ɵɵinject(i3.TpPasswordResetProcessorService)); }, token: QueryProcessorService, providedIn: "root" });
175
+ QueryProcessorService.decorators = [
176
+ { type: Injectable, args: [{
177
+ providedIn: 'root',
178
+ },] }
179
+ ];
180
+ QueryProcessorService.ctorParameters = () => [
181
+ { type: NgZone },
182
+ { type: KeyService },
183
+ { type: CommonProcessorsService },
184
+ { type: TpPasswordResetProcessorService }
185
+ ];
186
+ QueryProcessorService = __decorate([
187
+ RunOutsideAngular({
188
+ ngZoneName: 'ngZone',
189
+ })
190
+ ], QueryProcessorService);
191
+ export { QueryProcessorService };
192
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"query-processor.service.js","sourceRoot":"C:/Projects/test/projects/core/src/","sources":["lib/api/query-processor/query-processor.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, NgZone } from '@angular/core';\r\nimport { LrBadLogicException } from '../../_common/exceptions';\r\nimport { mapValuesMayAsync, promiseAllMayAsync } from '../../_common/utils';\r\nimport { KeyService } from '../../cryptography/key.service';\r\nimport {\r\n  CommonProcessorsService,\r\n  // FieldContext,\r\n  ProcessorCallback,\r\n  ProcessorCallbackParams,\r\n  ProcessorContext,\r\n  ProcessorOptions,\r\n  DefaultProcessorOptions,\r\n} from './common-processors.service';\r\nimport { TpPasswordResetService } from '../../trusted-parties/tp-password-reset.service';\r\nimport { RunOutsideAngular } from '../../_common/run-outside-angular';\r\nimport { TpPasswordResetProcessorService } from './tp-password-reset-processor.service';\r\n\r\nfunction extendPath(context: ProcessorContext, key: string): ProcessorContext {\r\n  return {\r\n    ...context,\r\n    path: [...context.path, key],\r\n  };\r\n}\r\n\r\n@RunOutsideAngular({\r\n  ngZoneName: 'ngZone',\r\n})\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class QueryProcessorService {\r\n  readonly TYPENAME = '__typename';\r\n  private processors: { [key: string]: ProcessorCallback } = {};\r\n\r\n  constructor(\r\n    private ngZone: NgZone,\r\n    private keyService: KeyService,\r\n    private common: CommonProcessorsService,\r\n    private tpprProcessor: TpPasswordResetProcessorService\r\n  ) {\r\n    this.registerProcessor(\r\n      'DirectoryNode',\r\n      common.series([\r\n        common.makeJsonParseProcessor({\r\n          plainFieldName: 'plainMeta',\r\n        }),\r\n        common.makeDecryptionProcessor({\r\n          cipherFieldName: 'cipherMeta',\r\n        }),\r\n      ])\r\n    );\r\n    this.registerProcessor(\r\n      'FileStateNode',\r\n      common.series([\r\n        common.makeJsonParseProcessor({\r\n          plainFieldName: 'plainMeta',\r\n        }),\r\n        common.makeDecryptionProcessor({\r\n          cipherFieldName: 'cipherMeta',\r\n        }),\r\n      ])\r\n    );\r\n    this.registerProcessor(\r\n      'ContactCardNode',\r\n      common.makeDecryptionProcessor({\r\n        cipherFieldName: 'cipherData',\r\n      })\r\n    );\r\n    this.registerProcessor(\r\n      'SharedContactCardNode',\r\n      common.series([\r\n        common.makeJsonParseProcessor({\r\n          plainFieldName: 'ownerPlainData',\r\n        }),\r\n        common.makeDecryptionProcessor({\r\n          cipherFieldName: 'ownerCipherData',\r\n          getKeyId: ({ field }) => {\r\n            return field.ownerKey.id;\r\n          },\r\n        }),\r\n        common.makeDecryptionProcessor({\r\n          cipherFieldName: 'receiverCipherData',\r\n          getKeyId: ({ field }) => {\r\n            return field.receiverKey.id;\r\n          },\r\n        }),\r\n        common.makeDecryptionProcessor({\r\n          cipherFieldName: 'sharedCipherData',\r\n          getKeyId: ({ field }) => field.sharedKey.id,\r\n        }),\r\n      ])\r\n    );\r\n    this.registerProcessor(\r\n      'TpPasswordResetNode',\r\n      this.tpprProcessor.makeTpPasswordResetNodeProcessor()\r\n    );\r\n    this.registerProcessor(\r\n      'SharedTpClaimApproverNode',\r\n      common.series([\r\n        common.makeDecryptionProcessor({\r\n          cipherFieldName: 'sharedCipherApprovalData',\r\n          getKeyId: ({ field }) => field.sharedKey.id,\r\n        }),\r\n        common.makeDecryptionProcessor({\r\n          cipherFieldName: 'sharedCipherPartialAssemblyKey',\r\n          getKeyId: ({ field }) => field.sharedKey.id,\r\n        }),\r\n      ])\r\n    );\r\n    this.registerProcessor(\r\n      'TpAssemblyAsApproverNode',\r\n      common.series([\r\n        common.makeDecryptionProcessor({\r\n          cipherFieldName: 'sharedCipherData',\r\n          getKeyId: ({ field }) => field.sharedKey.id,\r\n        }),\r\n      ])\r\n    );\r\n  }\r\n\r\n  async processQuery(\r\n    fields: { [key: string]: any },\r\n    options: ProcessorOptions\r\n  ) {\r\n    options = {\r\n      ...DefaultProcessorOptions,\r\n      ...options,\r\n    };\r\n\r\n    // The top level query does not have __typename\r\n    const ret = mapValuesMayAsync(fields, (field, key) =>\r\n      this.processField({\r\n        field,\r\n        context: {\r\n          path: [key],\r\n          processChildren: true,\r\n        },\r\n        options,\r\n      })\r\n    );\r\n    return ret;\r\n  }\r\n\r\n  // Either returns a Promise, or a value.\r\n  // The Promise<any> type is redundant but it shows that it can return a promise\r\n  // We are not using async on the function because we don't want auto promotion into a Promise, which\r\n  // always defer execution into the event loops. It is costly and unnecessary for objects\r\n  // with only native data types.\r\n  private async processField({\r\n    field,\r\n    context,\r\n    options,\r\n  }: ProcessorCallbackParams) {\r\n    if (field?.then) {\r\n      throw new LrBadLogicException(\r\n        'processField() should not receive thenable.'\r\n      );\r\n    }\r\n\r\n    if (field == null) {\r\n      return null;\r\n    }\r\n\r\n    const newParams: ProcessorCallbackParams = {\r\n      field,\r\n      context: {\r\n        ...context,\r\n        // Processors modifies this field to communicate back to the caller.\r\n        processChildren: true,\r\n      },\r\n      options,\r\n    };\r\n\r\n    // TODO allow registering processors by field name so we can process primitive fields as well.\r\n    // We have common fields like \"created\", \"modified\" that be processed based on name.\r\n    if (field[this.TYPENAME]) {\r\n      // It's a custom object type\r\n      const processor = this.processors[field[this.TYPENAME]];\r\n      if (processor) {\r\n        // Returns either a value or a promise.\r\n        field = processor(newParams);\r\n      }\r\n\r\n      const processChildren = (childField) => {\r\n        if (\r\n          context.processChildren &&\r\n          childField !== null &&\r\n          typeof childField === 'object'\r\n        ) {\r\n          return mapValuesMayAsync(childField, (x, key) =>\r\n            this.processField({\r\n              field: x,\r\n              context: extendPath(context, key),\r\n              options,\r\n            })\r\n          );\r\n        } else {\r\n          return childField;\r\n        }\r\n      };\r\n\r\n      // Keep processing all child fields\r\n      if (field.then) {\r\n        // Wait for field to resolve\r\n        field = field.then((resolvedField) => {\r\n          return processChildren(resolvedField);\r\n        });\r\n      } else {\r\n        // Field is already resolved\r\n        field = processChildren(field);\r\n      }\r\n    } else {\r\n      // Keep processing all child fields\r\n      if (context.processChildren) {\r\n        if (Array.isArray(field)) {\r\n          field = promiseAllMayAsync(\r\n            (field as Array<any>).map((x, i) =>\r\n              this.processField({\r\n                field: x,\r\n                context: extendPath(context, i.toString()),\r\n                options,\r\n              })\r\n            )\r\n          );\r\n        }\r\n      }\r\n    }\r\n\r\n    return field;\r\n  }\r\n\r\n  private registerProcessor(name: string, processor: ProcessorCallback) {\r\n    if (this.processors[name]) {\r\n      throw new LrBadLogicException(\r\n        `Processor for field ${name} already exists.`\r\n      );\r\n    }\r\n    this.processors[name] = processor;\r\n  }\r\n}\r\n"]}
@@ -0,0 +1,109 @@
1
+ import { __awaiter, __decorate } from "tslib";
2
+ import { Injectable, NgZone } from '@angular/core';
3
+ import { KeyGraphService } from '../../cryptography/key-graph.service';
4
+ import { RunOutsideAngular } from '../../_common/run-outside-angular';
5
+ import { processConnection, } from './common-processors.service';
6
+ import { LrBadRequestException } from '../../_common/exceptions';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "../../cryptography/key-graph.service";
9
+ let TpPasswordResetProcessorService = class TpPasswordResetProcessorService {
10
+ constructor(ngZone, keyGraph) {
11
+ this.ngZone = ngZone;
12
+ this.keyGraph = keyGraph;
13
+ }
14
+ processTpPasswordResetUserNode(node) {
15
+ var _a;
16
+ return __awaiter(this, void 0, void 0, function* () {
17
+ const pxk = ((_a = node.pxk) === null || _a === void 0 ? void 0 : _a.id) && (yield this.keyGraph.getKey(node.pxk.id));
18
+ const ret = Object.assign({}, node);
19
+ if (pxk && node.approvals) {
20
+ ret.approvals = yield Promise.all(node.approvals.map((approval) => this.processTpPasswordResetUserApprovalNode(approval, pxk)));
21
+ }
22
+ return ret;
23
+ });
24
+ }
25
+ processTpPasswordResetUserApprovalNode(approval, pxk) {
26
+ return __awaiter(this, void 0, void 0, function* () {
27
+ const ret = Object.assign({}, approval);
28
+ if (approval.receiverCipher) {
29
+ ret.receiverCipherClearJson = this.keyGraph.decryptFromString(pxk, approval.receiverCipher);
30
+ }
31
+ if (approval.receiverCipherPartialAssemblyKey) {
32
+ ret.receiverCipherPartialAssemblyKeyClearJson = this.keyGraph.decryptFromString(pxk, approval.receiverCipherPartialAssemblyKey);
33
+ }
34
+ return ret;
35
+ });
36
+ }
37
+ makeTpPasswordResetNodeProcessor() {
38
+ return ({ field, }) => __awaiter(this, void 0, void 0, function* () {
39
+ const ret = Object.assign({}, field);
40
+ if (field.assembly) {
41
+ if (field.applied == null) {
42
+ throw new LrBadRequestException('If you request for field "assembly" in the TpPasswordResetNode, then you must also request the "applied" field');
43
+ }
44
+ ret.assembly = yield this.processTpAssemblyNode(field.assembly, field.applied);
45
+ }
46
+ return ret;
47
+ });
48
+ }
49
+ processTpAssemblyNode(assembly, applied) {
50
+ return __awaiter(this, void 0, void 0, function* () {
51
+ // Subject key is encrypted user the master key. So if reset has been applied, then
52
+ // these keys are not available any more.
53
+ const { subjectKey, assemblyKey, assemblyCipherData, subAssemblies, } = assembly;
54
+ const ret = Object.assign(Object.assign({}, assembly), { subAssemblies: yield processConnection(subAssemblies, (node) => this.processTpSubAssemblyNode(node, subjectKey.id, applied)) });
55
+ if (!applied) {
56
+ if (assemblyCipherData) {
57
+ ret.assemblyCipherDataClearJson = yield this.keyGraph.decryptFromString(assemblyKey.id, assemblyCipherData);
58
+ }
59
+ }
60
+ return ret;
61
+ });
62
+ }
63
+ processTpSubAssemblyNode(subAssembly, subjectKeyId, applied) {
64
+ return __awaiter(this, void 0, void 0, function* () {
65
+ const { subjectCipherData, approvers } = subAssembly;
66
+ // const ret: TpSubAssemblyNode = {
67
+ // ...subAssembly,
68
+ // approvers: {
69
+ // ...approvers,
70
+ // edges: await Promise.all(
71
+ // approvers.edges.map(async (edge) => ({
72
+ // ...edge,
73
+ // node: await this.processTpAssemblyApproverNode(edge.node, applied),
74
+ // }))
75
+ // ),
76
+ // },
77
+ // };
78
+ const ret = Object.assign(Object.assign({}, subAssembly), { approvers: yield processConnection(approvers, (node) => this.processTpAssemblyApproverNode(node, applied)) });
79
+ if (!applied) {
80
+ if (subjectCipherData) {
81
+ ret.subjectCipherDataClearJson = yield this.keyGraph.decryptFromString(subjectKeyId, subjectCipherData);
82
+ }
83
+ }
84
+ return ret;
85
+ });
86
+ }
87
+ processTpAssemblyApproverNode(approver, applied) {
88
+ return __awaiter(this, void 0, void 0, function* () {
89
+ return approver;
90
+ });
91
+ }
92
+ };
93
+ TpPasswordResetProcessorService.ɵprov = i0.ɵɵdefineInjectable({ factory: function TpPasswordResetProcessorService_Factory() { return new TpPasswordResetProcessorService(i0.ɵɵinject(i0.NgZone), i0.ɵɵinject(i1.KeyGraphService)); }, token: TpPasswordResetProcessorService, providedIn: "root" });
94
+ TpPasswordResetProcessorService.decorators = [
95
+ { type: Injectable, args: [{
96
+ providedIn: 'root',
97
+ },] }
98
+ ];
99
+ TpPasswordResetProcessorService.ctorParameters = () => [
100
+ { type: NgZone },
101
+ { type: KeyGraphService }
102
+ ];
103
+ TpPasswordResetProcessorService = __decorate([
104
+ RunOutsideAngular({
105
+ ngZoneName: 'ngZone',
106
+ })
107
+ ], TpPasswordResetProcessorService);
108
+ export { TpPasswordResetProcessorService };
109
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tp-password-reset-processor.service.js","sourceRoot":"C:/Projects/test/projects/core/src/","sources":["lib/api/query-processor/tp-password-reset-processor.service.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,sCAAsC,CAAC;AACvE,OAAO,EAAE,iBAAiB,EAAE,MAAM,mCAAmC,CAAC;AAQtE,OAAO,EACL,iBAAiB,GAElB,MAAM,6BAA6B,CAAC;AAOrC,OAAO,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;;;IAQpD,+BAA+B,SAA/B,+BAA+B;IAC1C,YAAoB,MAAc,EAAU,QAAyB;QAAjD,WAAM,GAAN,MAAM,CAAQ;QAAU,aAAQ,GAAR,QAAQ,CAAiB;IAAG,CAAC;IAEnE,8BAA8B,CAClC,IAA6B;;;YAE7B,MAAM,GAAG,GAAG,OAAA,IAAI,CAAC,GAAG,0CAAE,EAAE,KAAI,CAAC,MAAM,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC;YAEtE,MAAM,GAAG,qBACJ,IAAI,CACR,CAAC;YAEF,IAAI,GAAG,IAAI,IAAI,CAAC,SAAS,EAAE;gBACzB,GAAG,CAAC,SAAS,GAAG,MAAM,OAAO,CAAC,GAAG,CAC/B,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAC9B,IAAI,CAAC,sCAAsC,CAAC,QAAQ,EAAE,GAAG,CAAC,CAC3D,CACF,CAAC;aACH;YAED,OAAO,GAAG,CAAC;;KACZ;IAEa,sCAAsC,CAClD,QAAyC,EACzC,GAAQ;;YAER,MAAM,GAAG,qBACJ,QAAQ,CACZ,CAAC;YAEF,IAAI,QAAQ,CAAC,cAAc,EAAE;gBAC3B,GAAG,CAAC,uBAAuB,GAAG,IAAI,CAAC,QAAQ,CAAC,iBAAiB,CAC3D,GAAG,EACH,QAAQ,CAAC,cAAc,CACxB,CAAC;aACH;YAED,IAAI,QAAQ,CAAC,gCAAgC,EAAE;gBAC7C,GAAG,CAAC,yCAAyC,GAAG,IAAI,CAAC,QAAQ,CAAC,iBAAiB,CAC7E,GAAG,EACH,QAAQ,CAAC,gCAAgC,CAC1C,CAAC;aACH;YACD,OAAO,GAAG,CAAC;QACb,CAAC;KAAA;IAED,gCAAgC;QAC9B,OAAO,CAAO,EACZ,KAAK,GACmB,EAAgC,EAAE;YAC1D,MAAM,GAAG,qBACJ,KAAK,CACT,CAAC;YAEF,IAAI,KAAK,CAAC,QAAQ,EAAE;gBAClB,IAAI,KAAK,CAAC,OAAO,IAAI,IAAI,EAAE;oBACzB,MAAM,IAAI,qBAAqB,CAC7B,gHAAgH,CACjH,CAAC;iBACH;gBAED,GAAG,CAAC,QAAQ,GAAG,MAAM,IAAI,CAAC,qBAAqB,CAC7C,KAAK,CAAC,QAAQ,EACd,KAAK,CAAC,OAAO,CACd,CAAC;aACH;YAED,OAAO,GAAG,CAAC;QACb,CAAC,CAAA,CAAC;IACJ,CAAC;IAEa,qBAAqB,CACjC,QAAwB,EACxB,OAAgB;;YAEhB,mFAAmF;YACnF,yCAAyC;YACzC,MAAM,EACJ,UAAU,EACV,WAAW,EACX,kBAAkB,EAClB,aAAa,GACd,GAAG,QAAQ,CAAC;YAEb,MAAM,GAAG,mCACJ,QAAQ,KACX,aAAa,EAAE,MAAM,iBAAiB,CAAC,aAAa,EAAE,CAAC,IAAI,EAAE,EAAE,CAC7D,IAAI,CAAC,wBAAwB,CAAC,IAAI,EAAE,UAAU,CAAC,EAAE,EAAE,OAAO,CAAC,CAC5D,GACF,CAAC;YAEF,IAAI,CAAC,OAAO,EAAE;gBACZ,IAAI,kBAAkB,EAAE;oBACtB,GAAG,CAAC,2BAA2B,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,iBAAiB,CACrE,WAAW,CAAC,EAAE,EACd,kBAAkB,CACnB,CAAC;iBACH;aACF;YAED,OAAO,GAAG,CAAC;QACb,CAAC;KAAA;IAEa,wBAAwB,CACpC,WAA8B,EAC9B,YAAgB,EAChB,OAAgB;;YAEhB,MAAM,EAAE,iBAAiB,EAAE,SAAS,EAAE,GAAG,WAAW,CAAC;YAErD,mCAAmC;YACnC,oBAAoB;YACpB,iBAAiB;YACjB,oBAAoB;YACpB,gCAAgC;YAChC,+CAA+C;YAC/C,mBAAmB;YACnB,8EAA8E;YAC9E,YAAY;YACZ,SAAS;YACT,OAAO;YACP,KAAK;YACL,MAAM,GAAG,mCACJ,WAAW,KACd,SAAS,EAAE,MAAM,iBAAiB,CAAC,SAAS,EAAE,CAAC,IAAI,EAAE,EAAE,CACrD,IAAI,CAAC,6BAA6B,CAAC,IAAI,EAAE,OAAO,CAAC,CAClD,GACF,CAAC;YAEF,IAAI,CAAC,OAAO,EAAE;gBACZ,IAAI,iBAAiB,EAAE;oBACrB,GAAG,CAAC,0BAA0B,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,iBAAiB,CACpE,YAAY,EACZ,iBAAiB,CAClB,CAAC;iBACH;aACF;YAED,OAAO,GAAG,CAAC;QACb,CAAC;KAAA;IAEa,6BAA6B,CACzC,QAAgC,EAChC,OAAgB;;YAEhB,OAAO,QAAQ,CAAC;QAClB,CAAC;KAAA;CACF,CAAA;;;YAvJA,UAAU,SAAC;gBACV,UAAU,EAAE,MAAM;aACnB;;;YA3BoB,MAAM;YAClB,eAAe;;AA2BX,+BAA+B;IAN3C,iBAAiB,CAAC;QACjB,UAAU,EAAE,QAAQ;KACrB,CAAC;GAIW,+BAA+B,CAoJ3C;SApJY,+BAA+B","sourcesContent":["import { Injectable, NgZone } from '@angular/core';\r\nimport { KeyGraphService } from '../../cryptography/key-graph.service';\r\nimport { RunOutsideAngular } from '../../_common/run-outside-angular';\r\nimport {\r\n  ID,\r\n  SharedTpAssemblyNode,\r\n  TpAssemblyApproverNode,\r\n  TpAssemblyNode,\r\n  TpSubAssemblyNode,\r\n} from '../types';\r\nimport {\r\n  processConnection,\r\n  ProcessorCallbackParams,\r\n} from './common-processors.service';\r\nimport {\r\n  TpPasswordResetUserNode,\r\n  TpPasswordResetUserApprovalNode,\r\n  TpPasswordResetNode,\r\n} from '../types';\r\nimport { Key } from '../../cryptography/cryptography.types';\r\nimport { LrBadRequestException } from '../../_common/exceptions';\r\n\r\n@RunOutsideAngular({\r\n  ngZoneName: 'ngZone',\r\n})\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class TpPasswordResetProcessorService {\r\n  constructor(private ngZone: NgZone, private keyGraph: KeyGraphService) {}\r\n\r\n  async processTpPasswordResetUserNode(\r\n    node: TpPasswordResetUserNode\r\n  ): Promise<TpPasswordResetUserNode> {\r\n    const pxk = node.pxk?.id && (await this.keyGraph.getKey(node.pxk.id));\r\n\r\n    const ret = {\r\n      ...node,\r\n    };\r\n\r\n    if (pxk && node.approvals) {\r\n      ret.approvals = await Promise.all(\r\n        node.approvals.map((approval) =>\r\n          this.processTpPasswordResetUserApprovalNode(approval, pxk)\r\n        )\r\n      );\r\n    }\r\n\r\n    return ret;\r\n  }\r\n\r\n  private async processTpPasswordResetUserApprovalNode(\r\n    approval: TpPasswordResetUserApprovalNode,\r\n    pxk: Key\r\n  ) {\r\n    const ret = {\r\n      ...approval,\r\n    };\r\n\r\n    if (approval.receiverCipher) {\r\n      ret.receiverCipherClearJson = this.keyGraph.decryptFromString(\r\n        pxk,\r\n        approval.receiverCipher\r\n      );\r\n    }\r\n\r\n    if (approval.receiverCipherPartialAssemblyKey) {\r\n      ret.receiverCipherPartialAssemblyKeyClearJson = this.keyGraph.decryptFromString(\r\n        pxk,\r\n        approval.receiverCipherPartialAssemblyKey\r\n      );\r\n    }\r\n    return ret;\r\n  }\r\n\r\n  makeTpPasswordResetNodeProcessor() {\r\n    return async ({\r\n      field,\r\n    }: ProcessorCallbackParams): Promise<TpPasswordResetNode> => {\r\n      const ret = {\r\n        ...field,\r\n      };\r\n\r\n      if (field.assembly) {\r\n        if (field.applied == null) {\r\n          throw new LrBadRequestException(\r\n            'If you request for field \"assembly\" in the TpPasswordResetNode, then you must also request the \"applied\" field'\r\n          );\r\n        }\r\n\r\n        ret.assembly = await this.processTpAssemblyNode(\r\n          field.assembly,\r\n          field.applied\r\n        );\r\n      }\r\n\r\n      return ret;\r\n    };\r\n  }\r\n\r\n  private async processTpAssemblyNode(\r\n    assembly: TpAssemblyNode,\r\n    applied: boolean\r\n  ): Promise<TpAssemblyNode> {\r\n    // Subject key is encrypted user the master key. So if reset has been applied, then\r\n    // these keys are not available any more.\r\n    const {\r\n      subjectKey,\r\n      assemblyKey,\r\n      assemblyCipherData,\r\n      subAssemblies,\r\n    } = assembly;\r\n\r\n    const ret: TpAssemblyNode = {\r\n      ...assembly,\r\n      subAssemblies: await processConnection(subAssemblies, (node) =>\r\n        this.processTpSubAssemblyNode(node, subjectKey.id, applied)\r\n      ),\r\n    };\r\n\r\n    if (!applied) {\r\n      if (assemblyCipherData) {\r\n        ret.assemblyCipherDataClearJson = await this.keyGraph.decryptFromString(\r\n          assemblyKey.id,\r\n          assemblyCipherData\r\n        );\r\n      }\r\n    }\r\n\r\n    return ret;\r\n  }\r\n\r\n  private async processTpSubAssemblyNode(\r\n    subAssembly: TpSubAssemblyNode,\r\n    subjectKeyId: ID,\r\n    applied: boolean\r\n  ): Promise<TpSubAssemblyNode> {\r\n    const { subjectCipherData, approvers } = subAssembly;\r\n\r\n    // const ret: TpSubAssemblyNode = {\r\n    //   ...subAssembly,\r\n    //   approvers: {\r\n    //     ...approvers,\r\n    //     edges: await Promise.all(\r\n    //       approvers.edges.map(async (edge) => ({\r\n    //         ...edge,\r\n    //         node: await this.processTpAssemblyApproverNode(edge.node, applied),\r\n    //       }))\r\n    //     ),\r\n    //   },\r\n    // };\r\n    const ret: TpSubAssemblyNode = {\r\n      ...subAssembly,\r\n      approvers: await processConnection(approvers, (node) =>\r\n        this.processTpAssemblyApproverNode(node, applied)\r\n      ),\r\n    };\r\n\r\n    if (!applied) {\r\n      if (subjectCipherData) {\r\n        ret.subjectCipherDataClearJson = await this.keyGraph.decryptFromString(\r\n          subjectKeyId,\r\n          subjectCipherData\r\n        );\r\n      }\r\n    }\r\n\r\n    return ret;\r\n  }\r\n\r\n  private async processTpAssemblyApproverNode(\r\n    approver: TpAssemblyApproverNode,\r\n    applied: boolean\r\n  ) {\r\n    return approver;\r\n  }\r\n}\r\n"]}
@@ -0,0 +1,119 @@
1
+ import { __awaiter } from "tslib";
2
+ import { Injectable } from '@angular/core';
3
+ import gql from 'graphql-tag';
4
+ import { EncryptionService } from '../cryptography/encryption.service';
5
+ import { KeyGraphService } from '../cryptography/key-graph.service';
6
+ import { KeyService } from '../cryptography/key.service';
7
+ import { ContactCardName } from '../users/profile.types';
8
+ import { LrApolloService } from './lr-apollo.service';
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "../cryptography/key.service";
11
+ import * as i2 from "./lr-apollo.service";
12
+ import * as i3 from "../cryptography/key-graph.service";
13
+ import * as i4 from "../cryptography/encryption.service";
14
+ export const SharedContactCardFields = `
15
+ id
16
+ owner {
17
+ id
18
+ username
19
+ }
20
+ ownerKey {
21
+ id
22
+ }
23
+ ownerCipherData
24
+ receiver {
25
+ id
26
+ username
27
+ }
28
+ receiverKey {
29
+ id
30
+ }
31
+ receiverCipherData
32
+ sharedKey {
33
+ id
34
+ }
35
+ sharedCipherData
36
+ sharedCipherDataSig
37
+ sharedCipherDataSigPxk {
38
+ id
39
+ }
40
+ `;
41
+ const UpdateOwnedContactCard = gql `
42
+ mutation UpdateOwnedContactCard(
43
+ $input: UpdateOwnedContactCardInput!
44
+ ) {
45
+ updateOwnedContactCard(
46
+ input: $input
47
+ ) {
48
+ ownedContactCard {
49
+ ${SharedContactCardFields}
50
+ }
51
+ }
52
+ }`;
53
+ export class SharedContactCardService {
54
+ constructor(keyService, lrApollo, keyGraph, encryptionService) {
55
+ this.keyService = keyService;
56
+ this.lrApollo = lrApollo;
57
+ this.keyGraph = keyGraph;
58
+ this.encryptionService = encryptionService;
59
+ }
60
+ decryptSharedTrustedPartyDetails(cc) {
61
+ return __awaiter(this, void 0, void 0, function* () {
62
+ const details = yield this.decryptTrustedPartyDetails(cc);
63
+ return Object.assign({ id: cc.id, ownedKeyId: cc.ownerKey.id, sharedKeyId: cc.sharedKey.id }, details);
64
+ });
65
+ }
66
+ decryptTrustedPartyDetails(cc) {
67
+ return __awaiter(this, void 0, void 0, function* () {
68
+ if (cc && cc.sharedKey && cc.sharedCipherData) {
69
+ try {
70
+ return yield this.encryptionService.decrypt(yield this.keyGraph.getJwkKey(cc.sharedKey.id), cc.sharedCipherData);
71
+ }
72
+ catch (e) {
73
+ console.error('Cannot decrypt trusted party details', e);
74
+ }
75
+ }
76
+ return null;
77
+ });
78
+ }
79
+ updateMySharedContactCard(id, ownedKeyId, sharedKeyId, contactCard) {
80
+ return __awaiter(this, void 0, void 0, function* () {
81
+ const ownerKey = yield this.keyGraph.getKey(ownedKeyId);
82
+ const sharedKey = yield this.keyGraph.getKey(sharedKeyId);
83
+ const sigPxk = yield this.keyService.getCurrentSigPxk();
84
+ const sharedCipherData = yield this.encryptionService.encrypt(sharedKey.jwk, contactCard);
85
+ const sharedCipherDataSig = JSON.stringify(yield this.encryptionService.sign(sigPxk.jwk, sharedCipherData));
86
+ const ownerPlainData = {
87
+ name: new ContactCardName(contactCard.name),
88
+ };
89
+ const ownerPlainDataSig = JSON.stringify(yield this.encryptionService.sign(sigPxk.jwk, ownerPlainData));
90
+ yield this.lrApollo.mutate({
91
+ mutation: UpdateOwnedContactCard,
92
+ variables: {
93
+ input: {
94
+ id,
95
+ ownerCipherData: '',
96
+ ownerKeyId: ownerKey.id,
97
+ sharedCipherDataSig,
98
+ sharedKeyId: sharedKey.id,
99
+ sigPxkId: sigPxk.id,
100
+ ownerPlainDataSig,
101
+ },
102
+ },
103
+ });
104
+ });
105
+ }
106
+ }
107
+ SharedContactCardService.ɵprov = i0.ɵɵdefineInjectable({ factory: function SharedContactCardService_Factory() { return new SharedContactCardService(i0.ɵɵinject(i1.KeyService), i0.ɵɵinject(i2.LrApolloService), i0.ɵɵinject(i3.KeyGraphService), i0.ɵɵinject(i4.EncryptionService)); }, token: SharedContactCardService, providedIn: "root" });
108
+ SharedContactCardService.decorators = [
109
+ { type: Injectable, args: [{
110
+ providedIn: 'root',
111
+ },] }
112
+ ];
113
+ SharedContactCardService.ctorParameters = () => [
114
+ { type: KeyService },
115
+ { type: LrApolloService },
116
+ { type: KeyGraphService },
117
+ { type: EncryptionService }
118
+ ];
119
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"shared-contact-card.service.js","sourceRoot":"C:/Projects/test/projects/core/src/","sources":["lib/api/shared-contact-card.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport gql from 'graphql-tag';\r\nimport { Key } from '../cryptography/cryptography.types';\r\nimport { EncryptionService } from '../cryptography/encryption.service';\r\nimport { KeyGraphService } from '../cryptography/key-graph.service';\r\nimport { KeyService } from '../cryptography/key.service';\r\nimport { SharedTrustedPartyDetails } from '../trusted-parties/trusted-party.types';\r\nimport { ContactCardName, TrustedPartyDetails } from '../users/profile.types';\r\nimport { User } from '../users/user.types';\r\nimport { KeyGraphField } from '../_common/queries.gql';\r\nimport { LrApolloService } from './lr-apollo.service';\r\n\r\nexport const SharedContactCardFields = `\r\n  id\r\n  owner {\r\n    id\r\n    username\r\n  }\r\n  ownerKey {\r\n    id\r\n  }\r\n  ownerCipherData\r\n  receiver {\r\n    id\r\n    username\r\n  }\r\n  receiverKey {\r\n    id\r\n  }\r\n  receiverCipherData\r\n  sharedKey {\r\n    id\r\n  }\r\n  sharedCipherData\r\n  sharedCipherDataSig\r\n  sharedCipherDataSigPxk {\r\n    id\r\n  }\r\n`;\r\n\r\nconst UpdateOwnedContactCard = gql`\r\nmutation UpdateOwnedContactCard(\r\n  $input: UpdateOwnedContactCardInput!\r\n) {\r\n  updateOwnedContactCard(\r\n    input: $input\r\n  ) {\r\n    ownedContactCard {\r\n      ${SharedContactCardFields}\r\n    }\r\n  }\r\n}`;\r\n\r\ninterface UpdateOwnedContactCard {\r\n  updateOwnedContactCard: {\r\n    ownedContactCard: SharedContactCard;\r\n  };\r\n}\r\n\r\nexport interface SharedContactCard {\r\n  id: string;\r\n  owner: User;\r\n  ownerKey: Key;\r\n  ownerCipherData: string;\r\n  receiver: User;\r\n  receiverKey: Key;\r\n  receiverCipherData: string;\r\n  sharedKey: Key;\r\n  sharedCipherData: string;\r\n  // Decrypted\r\n  plainOwnerCipherDataJson: any;\r\n  plainReceiverCipherDataJson: any;\r\n  plainSharedCipherDataJson: any;\r\n}\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class SharedContactCardService {\r\n  constructor(\r\n    private keyService: KeyService,\r\n    private lrApollo: LrApolloService,\r\n    private keyGraph: KeyGraphService,\r\n    private encryptionService: EncryptionService\r\n  ) {}\r\n\r\n  async decryptSharedTrustedPartyDetails(\r\n    cc: SharedContactCard\r\n  ): Promise<SharedTrustedPartyDetails> {\r\n    const details = await this.decryptTrustedPartyDetails(cc);\r\n\r\n    return {\r\n      id: cc.id,\r\n      ownedKeyId: cc.ownerKey.id,\r\n      sharedKeyId: cc.sharedKey.id,\r\n      ...details,\r\n    };\r\n  }\r\n\r\n  async decryptTrustedPartyDetails(\r\n    cc: SharedContactCard\r\n  ): Promise<TrustedPartyDetails> {\r\n    if (cc && cc.sharedKey && cc.sharedCipherData) {\r\n      try {\r\n        return await this.encryptionService.decrypt(\r\n          await this.keyGraph.getJwkKey(cc.sharedKey.id),\r\n          cc.sharedCipherData\r\n        );\r\n      } catch (e) {\r\n        console.error('Cannot decrypt trusted party details', e);\r\n      }\r\n    }\r\n    return null;\r\n  }\r\n\r\n  async updateMySharedContactCard(\r\n    id: string,\r\n    ownedKeyId: string,\r\n    sharedKeyId: string,\r\n    contactCard: TrustedPartyDetails\r\n  ): Promise<void> {\r\n    const ownerKey = await this.keyGraph.getKey(ownedKeyId);\r\n    const sharedKey = await this.keyGraph.getKey(sharedKeyId);\r\n    const sigPxk = await this.keyService.getCurrentSigPxk();\r\n\r\n    const sharedCipherData = await this.encryptionService.encrypt(\r\n      sharedKey.jwk,\r\n      contactCard\r\n    );\r\n    const sharedCipherDataSig = JSON.stringify(\r\n      await this.encryptionService.sign(sigPxk.jwk, sharedCipherData)\r\n    );\r\n\r\n    const ownerPlainData = {\r\n      name: new ContactCardName(contactCard.name),\r\n    };\r\n    const ownerPlainDataSig = JSON.stringify(\r\n      await this.encryptionService.sign(sigPxk.jwk, ownerPlainData)\r\n    );\r\n\r\n    await this.lrApollo.mutate<UpdateOwnedContactCard>({\r\n      mutation: UpdateOwnedContactCard,\r\n      variables: {\r\n        input: {\r\n          id,\r\n          ownerCipherData: '',\r\n          ownerKeyId: ownerKey.id,\r\n          sharedCipherDataSig,\r\n          sharedKeyId: sharedKey.id,\r\n          sigPxkId: sigPxk.id,\r\n          ownerPlainDataSig,\r\n        },\r\n      },\r\n    });\r\n  }\r\n}\r\n"]}
@@ -0,0 +1,41 @@
1
+ import { gqlTyped } from '../_common/ast';
2
+ export const UpdateOwnedContactCardMutation = gqlTyped `
3
+ mutation UpdateOwnedContactCardMutation(
4
+ $input: UpdateOwnedContactCardInput!
5
+ ) {
6
+ updateOwnedContactCard(input: $input) {
7
+ ownedContactCard {
8
+ id
9
+ }
10
+ }
11
+ }`;
12
+ export const UpdateReceivedContactCardMutation = gqlTyped `
13
+ mutation UpdateReceivedContactCardMutation(
14
+ $input: UpdateReceivedContactCardInput!
15
+ ) {
16
+ updateReceivedContactCard(input: $input) {
17
+ receivedContactCard {
18
+ id
19
+ }
20
+ }
21
+ }`;
22
+ export const GetOwnedContactCardKeyIdsQuery = gqlTyped `
23
+ query GetOwnedContactCardKeyIdsQuery($id: LrRelayIdInput!) {
24
+ ownedContactCard(id: $id) {
25
+ sharedKey {
26
+ id
27
+ }
28
+ ownerKey {
29
+ id
30
+ }
31
+ }
32
+ }`;
33
+ export const GetReceivedContactCardKeyIdQuery = gqlTyped `
34
+ query GetReceivedContactCardKeyIdQuery($id: LrRelayIdInput!) {
35
+ receivedContactCard(id: $id) {
36
+ receiverKey {
37
+ id
38
+ }
39
+ }
40
+ }`;
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2hhcmVkLWNvbnRhY3QtY2FyZDIuZ3FsLmpzIiwic291cmNlUm9vdCI6IkM6L1Byb2plY3RzL3Rlc3QvcHJvamVjdHMvY29yZS9zcmMvIiwic291cmNlcyI6WyJsaWIvYXBpL3NoYXJlZC1jb250YWN0LWNhcmQyLmdxbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFVMUMsTUFBTSxDQUFDLE1BQU0sOEJBQThCLEdBQUcsUUFBUSxDQUFnQzs7Ozs7Ozs7O0VBU3BGLENBQUM7QUFTSCxNQUFNLENBQUMsTUFBTSxpQ0FBaUMsR0FBRyxRQUFRLENBQW1DOzs7Ozs7Ozs7RUFTMUYsQ0FBQztBQVlILE1BQU0sQ0FBQyxNQUFNLDhCQUE4QixHQUFHLFFBQVEsQ0FBZ0M7Ozs7Ozs7Ozs7RUFVcEYsQ0FBQztBQVNILE1BQU0sQ0FBQyxNQUFNLGdDQUFnQyxHQUFHLFFBQVEsQ0FBa0M7Ozs7Ozs7RUFPeEYsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGdxbFR5cGVkIH0gZnJvbSAnLi4vX2NvbW1vbi9hc3QnO1xyXG5pbXBvcnQgeyBJRCB9IGZyb20gJy4vdHlwZXMnO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBVcGRhdGVPd25lZENvbnRhY3RDYXJkTXV0YXRpb24ge1xyXG4gIHVwZGF0ZU93bmVkQ29udGFjdENhcmQ6IHtcclxuICAgIG93bmVkQ29udGFjdENhcmQ6IHtcclxuICAgICAgaWQ6IElEO1xyXG4gICAgfTtcclxuICB9O1xyXG59XHJcbmV4cG9ydCBjb25zdCBVcGRhdGVPd25lZENvbnRhY3RDYXJkTXV0YXRpb24gPSBncWxUeXBlZDxVcGRhdGVPd25lZENvbnRhY3RDYXJkTXV0YXRpb24+YFxyXG5tdXRhdGlvbiBVcGRhdGVPd25lZENvbnRhY3RDYXJkTXV0YXRpb24oXHJcbiAgJGlucHV0OiBVcGRhdGVPd25lZENvbnRhY3RDYXJkSW5wdXQhXHJcbikge1xyXG4gIHVwZGF0ZU93bmVkQ29udGFjdENhcmQoaW5wdXQ6ICRpbnB1dCkge1xyXG4gICAgb3duZWRDb250YWN0Q2FyZCB7XHJcbiAgICAgIGlkXHJcbiAgICB9XHJcbiAgfVxyXG59YDtcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgVXBkYXRlUmVjZWl2ZWRDb250YWN0Q2FyZE11dGF0aW9uIHtcclxuICB1cGRhdGVSZWNlaXZlZENvbnRhY3RDYXJkOiB7XHJcbiAgICByZWNlaXZlZENvbnRhY3RDYXJkOiB7XHJcbiAgICAgIGlkOiBJRDtcclxuICAgIH07XHJcbiAgfTtcclxufVxyXG5leHBvcnQgY29uc3QgVXBkYXRlUmVjZWl2ZWRDb250YWN0Q2FyZE11dGF0aW9uID0gZ3FsVHlwZWQ8VXBkYXRlUmVjZWl2ZWRDb250YWN0Q2FyZE11dGF0aW9uPmBcclxubXV0YXRpb24gVXBkYXRlUmVjZWl2ZWRDb250YWN0Q2FyZE11dGF0aW9uKFxyXG4gICRpbnB1dDogVXBkYXRlUmVjZWl2ZWRDb250YWN0Q2FyZElucHV0IVxyXG4pIHtcclxuICB1cGRhdGVSZWNlaXZlZENvbnRhY3RDYXJkKGlucHV0OiAkaW5wdXQpIHtcclxuICAgIHJlY2VpdmVkQ29udGFjdENhcmQge1xyXG4gICAgICBpZFxyXG4gICAgfVxyXG4gIH1cclxufWA7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEdldE93bmVkQ29udGFjdENhcmRLZXlJZHNRdWVyeSB7XHJcbiAgb3duZWRDb250YWN0Q2FyZDoge1xyXG4gICAgc2hhcmVkS2V5OiB7XHJcbiAgICAgIGlkOiBJRDtcclxuICAgIH07XHJcbiAgICBvd25lcktleToge1xyXG4gICAgICBpZDogSUQ7XHJcbiAgICB9O1xyXG4gIH07XHJcbn1cclxuZXhwb3J0IGNvbnN0IEdldE93bmVkQ29udGFjdENhcmRLZXlJZHNRdWVyeSA9IGdxbFR5cGVkPEdldE93bmVkQ29udGFjdENhcmRLZXlJZHNRdWVyeT5gXHJcbnF1ZXJ5IEdldE93bmVkQ29udGFjdENhcmRLZXlJZHNRdWVyeSgkaWQ6IExyUmVsYXlJZElucHV0ISkge1xyXG4gIG93bmVkQ29udGFjdENhcmQoaWQ6ICRpZCkge1xyXG4gICAgc2hhcmVkS2V5IHtcclxuICAgICAgaWRcclxuICAgIH1cclxuICAgIG93bmVyS2V5IHtcclxuICAgICAgaWRcclxuICAgIH1cclxuICB9XHJcbn1gO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBHZXRSZWNlaXZlZENvbnRhY3RDYXJkS2V5SWRRdWVyeSB7XHJcbiAgcmVjZWl2ZWRDb250YWN0Q2FyZDoge1xyXG4gICAgcmVjZWl2ZXJLZXk6IHtcclxuICAgICAgaWQ6IElEO1xyXG4gICAgfTtcclxuICB9O1xyXG59XHJcbmV4cG9ydCBjb25zdCBHZXRSZWNlaXZlZENvbnRhY3RDYXJkS2V5SWRRdWVyeSA9IGdxbFR5cGVkPEdldFJlY2VpdmVkQ29udGFjdENhcmRLZXlJZFF1ZXJ5PmBcclxucXVlcnkgR2V0UmVjZWl2ZWRDb250YWN0Q2FyZEtleUlkUXVlcnkoJGlkOiBMclJlbGF5SWRJbnB1dCEpIHtcclxuICByZWNlaXZlZENvbnRhY3RDYXJkKGlkOiAkaWQpIHtcclxuICAgIHJlY2VpdmVyS2V5IHtcclxuICAgICAgaWRcclxuICAgIH1cclxuICB9XHJcbn1gO1xyXG4iXX0=