@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.
- package/README.md +62 -0
- package/bundles/lifeready-core.umd.js +15939 -0
- package/bundles/lifeready-core.umd.js.map +1 -0
- package/bundles/lifeready-core.umd.min.js +2 -0
- package/bundles/lifeready-core.umd.min.js.map +1 -0
- package/esm2015/lib/_common/ast.js +40 -0
- package/esm2015/lib/_common/deferred-promise.js +24 -0
- package/esm2015/lib/_common/exceptions.js +157 -0
- package/esm2015/lib/_common/queries.gql.js +190 -0
- package/esm2015/lib/_common/run-outside-angular.js +79 -0
- package/esm2015/lib/_common/types.js +1 -0
- package/esm2015/lib/_common/utils.js +44 -0
- package/esm2015/lib/api/contact-card.gql.js +79 -0
- package/esm2015/lib/api/contact-card.service.js +154 -0
- package/esm2015/lib/api/contact-card2.gql.js +60 -0
- package/esm2015/lib/api/contact-card2.service.js +103 -0
- package/esm2015/lib/api/file.service.js +74 -0
- package/esm2015/lib/api/item2.gql.js +110 -0
- package/esm2015/lib/api/item2.service.js +311 -0
- package/esm2015/lib/api/key-exchange.gql.js +188 -0
- package/esm2015/lib/api/key-exchange.service.js +442 -0
- package/esm2015/lib/api/key-exchange.types.js +18 -0
- package/esm2015/lib/api/key-exchange2.gql.js +171 -0
- package/esm2015/lib/api/key-exchange2.service.js +479 -0
- package/esm2015/lib/api/lock.gql.js +40 -0
- package/esm2015/lib/api/lock.service.js +64 -0
- package/esm2015/lib/api/lr-apollo.service.js +46 -0
- package/esm2015/lib/api/lr-graphql/index.js +6 -0
- package/esm2015/lib/api/lr-graphql/lr-graphql.service.js +155 -0
- package/esm2015/lib/api/lr-graphql/lr-merged-mutation.js +213 -0
- package/esm2015/lib/api/lr-graphql/lr-mutation-base.js +51 -0
- package/esm2015/lib/api/lr-graphql/lr-mutation.js +48 -0
- package/esm2015/lib/api/lr-graphql/lr.service.js +18 -0
- package/esm2015/lib/api/message.service.js +138 -0
- package/esm2015/lib/api/persist.service.js +181 -0
- package/esm2015/lib/api/query-processor/common-processors.service.js +93 -0
- package/esm2015/lib/api/query-processor/index.js +3 -0
- package/esm2015/lib/api/query-processor/query-processor.service.js +192 -0
- package/esm2015/lib/api/query-processor/tp-password-reset-processor.service.js +109 -0
- package/esm2015/lib/api/shared-contact-card.service.js +119 -0
- package/esm2015/lib/api/shared-contact-card2.gql.js +41 -0
- package/esm2015/lib/api/shared-contact-card2.service.js +117 -0
- package/esm2015/lib/api/time.service.js +146 -0
- package/esm2015/lib/api/types/graphql.types.js +7 -0
- package/esm2015/lib/api/types/index.js +3 -0
- package/esm2015/lib/api/types/lr-graphql.types.js +71 -0
- package/esm2015/lib/auth/auth.config.js +57 -0
- package/esm2015/lib/auth/auth.gql.js +48 -0
- package/esm2015/lib/auth/auth.types.js +27 -0
- package/esm2015/lib/auth/idle.service.js +168 -0
- package/esm2015/lib/auth/idle.types.js +7 -0
- package/esm2015/lib/auth/lbop.service.js +355 -0
- package/esm2015/lib/auth/life-ready-auth.service.js +333 -0
- package/esm2015/lib/auth/password.service.js +320 -0
- package/esm2015/lib/auth/register.service.js +172 -0
- package/esm2015/lib/auth/two-factor.service.js +74 -0
- package/esm2015/lib/category/category-meta.service.js +99 -0
- package/esm2015/lib/category/category.gql.js +406 -0
- package/esm2015/lib/category/category.service.js +390 -0
- package/esm2015/lib/category/category.types.js +29 -0
- package/esm2015/lib/cryptography/cryptography.types.js +11 -0
- package/esm2015/lib/cryptography/encryption.service.js +189 -0
- package/esm2015/lib/cryptography/key-factory.service.js +237 -0
- package/esm2015/lib/cryptography/key-graph.service.js +280 -0
- package/esm2015/lib/cryptography/key-meta.service.js +200 -0
- package/esm2015/lib/cryptography/key.service.js +124 -0
- package/esm2015/lib/cryptography/slip39.service.js +169 -0
- package/esm2015/lib/cryptography/web-crypto.service.js +29 -0
- package/esm2015/lib/life-ready.config.js +84 -0
- package/esm2015/lib/life-ready.module.js +74 -0
- package/esm2015/lib/plan/plan.gql.js +123 -0
- package/esm2015/lib/plan/plan.service.js +149 -0
- package/esm2015/lib/plan/plan.types.js +11 -0
- package/esm2015/lib/record/record-attachment.service.js +101 -0
- package/esm2015/lib/record/record.gql.js +179 -0
- package/esm2015/lib/record/record.service.js +206 -0
- package/esm2015/lib/record/record.types.js +15 -0
- package/esm2015/lib/record-type/record-type.service.js +75 -0
- package/esm2015/lib/record-type/record-type.types.js +28 -0
- package/esm2015/lib/scenario/approvals/scenario-approval.gql.js +105 -0
- package/esm2015/lib/scenario/approvals/scenario-approval.types.js +1 -0
- package/esm2015/lib/scenario/approvals/scenario-approver.service.js +300 -0
- package/esm2015/lib/scenario/claimants/scenario-claimant.gql.js +52 -0
- package/esm2015/lib/scenario/claimants/scenario-claimant.service.js +97 -0
- package/esm2015/lib/scenario/claimants/scenario-claimant.types.js +1 -0
- package/esm2015/lib/scenario/receivers/scenario-receiver.gql.js +150 -0
- package/esm2015/lib/scenario/receivers/scenario-receiver.service.js +229 -0
- package/esm2015/lib/scenario/receivers/scenario-receiver.types.js +1 -0
- package/esm2015/lib/scenario/scenario-setup.service.js +269 -0
- package/esm2015/lib/scenario/scenario.gql.js +368 -0
- package/esm2015/lib/scenario/scenario.service.js +611 -0
- package/esm2015/lib/scenario/scenario.types.js +64 -0
- package/esm2015/lib/search/search.gql.js +62 -0
- package/esm2015/lib/search/search.service.js +156 -0
- package/esm2015/lib/search/search.types.js +6 -0
- package/esm2015/lib/trusted-parties/tp-password-reset-request.service.js +112 -0
- package/esm2015/lib/trusted-parties/tp-password-reset-user.service.js +266 -0
- package/esm2015/lib/trusted-parties/tp-password-reset.gql.js +232 -0
- package/esm2015/lib/trusted-parties/tp-password-reset.service.js +300 -0
- package/esm2015/lib/trusted-parties/trusted-party.gql.js +148 -0
- package/esm2015/lib/trusted-parties/trusted-party.service.js +326 -0
- package/esm2015/lib/trusted-parties/trusted-party.types.js +41 -0
- package/esm2015/lib/trusted-parties/trusted-party2.gql.js +87 -0
- package/esm2015/lib/trusted-parties/trusted-party2.service.js +215 -0
- package/esm2015/lib/users/profile-details.service.js +214 -0
- package/esm2015/lib/users/profile.gql.js +97 -0
- package/esm2015/lib/users/profile.service.js +169 -0
- package/esm2015/lib/users/profile.types.js +34 -0
- package/esm2015/lib/users/user.gql.js +60 -0
- package/esm2015/lib/users/user.service.js +79 -0
- package/esm2015/lib/users/user.types.js +5 -0
- package/esm2015/lifeready-core.js +10 -0
- package/esm2015/public-api.js +81 -0
- package/fesm2015/lifeready-core.js +13290 -0
- package/fesm2015/lifeready-core.js.map +1 -0
- package/lib/_common/ast.d.ts +11 -0
- package/lib/_common/deferred-promise.d.ts +12 -0
- package/lib/_common/exceptions.d.ts +109 -0
- package/lib/_common/queries.gql.d.ts +10 -0
- package/lib/_common/run-outside-angular.d.ts +14 -0
- package/lib/_common/types.d.ts +10 -0
- package/lib/_common/utils.d.ts +3 -0
- package/lib/api/contact-card.gql.d.ts +7 -0
- package/lib/api/contact-card.service.d.ts +52 -0
- package/lib/api/contact-card2.gql.d.ts +34 -0
- package/lib/api/contact-card2.service.d.ts +49 -0
- package/lib/api/file.service.d.ts +18 -0
- package/lib/api/item2.gql.d.ts +96 -0
- package/lib/api/item2.service.d.ts +177 -0
- package/lib/api/key-exchange.gql.d.ts +9 -0
- package/lib/api/key-exchange.service.d.ts +39 -0
- package/lib/api/key-exchange.types.d.ts +196 -0
- package/lib/api/key-exchange2.gql.d.ts +125 -0
- package/lib/api/key-exchange2.service.d.ts +187 -0
- package/lib/api/lock.gql.d.ts +27 -0
- package/lib/api/lock.service.d.ts +25 -0
- package/lib/api/lr-apollo.service.d.ts +15 -0
- package/lib/api/lr-graphql/index.d.ts +5 -0
- package/lib/api/lr-graphql/lr-graphql.service.d.ts +60 -0
- package/lib/api/lr-graphql/lr-merged-mutation.d.ts +27 -0
- package/lib/api/lr-graphql/lr-mutation-base.d.ts +28 -0
- package/lib/api/lr-graphql/lr-mutation.d.ts +8 -0
- package/lib/api/lr-graphql/lr.service.d.ts +9 -0
- package/lib/api/message.service.d.ts +58 -0
- package/lib/api/persist.service.d.ts +31 -0
- package/lib/api/query-processor/common-processors.service.d.ts +36 -0
- package/lib/api/query-processor/index.d.ts +2 -0
- package/lib/api/query-processor/query-processor.service.d.ts +18 -0
- package/lib/api/query-processor/tp-password-reset-processor.service.d.ts +15 -0
- package/lib/api/shared-contact-card.service.d.ts +33 -0
- package/lib/api/shared-contact-card2.gql.d.ts +36 -0
- package/lib/api/shared-contact-card2.service.d.ts +45 -0
- package/lib/api/time.service.d.ts +16 -0
- package/lib/api/types/graphql.types.d.ts +29 -0
- package/lib/api/types/index.d.ts +2 -0
- package/lib/api/types/lr-graphql.types.d.ts +385 -0
- package/lib/auth/auth.config.d.ts +5 -0
- package/lib/auth/auth.gql.d.ts +15 -0
- package/lib/auth/auth.types.d.ts +66 -0
- package/lib/auth/idle.service.d.ts +40 -0
- package/lib/auth/idle.types.d.ts +10 -0
- package/lib/auth/lbop.service.d.ts +91 -0
- package/lib/auth/life-ready-auth.service.d.ts +46 -0
- package/lib/auth/password.service.d.ts +78 -0
- package/lib/auth/register.service.d.ts +25 -0
- package/lib/auth/two-factor.service.d.ts +15 -0
- package/lib/category/category-meta.service.d.ts +23 -0
- package/lib/category/category.gql.d.ts +45 -0
- package/lib/category/category.service.d.ts +67 -0
- package/lib/category/category.types.d.ts +79 -0
- package/lib/cryptography/cryptography.types.d.ts +83 -0
- package/lib/cryptography/encryption.service.d.ts +41 -0
- package/lib/cryptography/key-factory.service.d.ts +38 -0
- package/lib/cryptography/key-graph.service.d.ts +33 -0
- package/lib/cryptography/key-meta.service.d.ts +44 -0
- package/lib/cryptography/key.service.d.ts +36 -0
- package/lib/cryptography/slip39.service.d.ts +43 -0
- package/lib/cryptography/web-crypto.service.d.ts +5 -0
- package/lib/life-ready.config.d.ts +14 -0
- package/lib/life-ready.module.d.ts +5 -0
- package/lib/plan/plan.gql.d.ts +11 -0
- package/lib/plan/plan.service.d.ts +33 -0
- package/lib/plan/plan.types.d.ts +31 -0
- package/lib/record/record-attachment.service.d.ts +16 -0
- package/lib/record/record.gql.d.ts +14 -0
- package/lib/record/record.service.d.ts +25 -0
- package/lib/record/record.types.d.ts +57 -0
- package/lib/record-type/record-type.service.d.ts +11 -0
- package/lib/record-type/record-type.types.d.ts +50 -0
- package/lib/scenario/approvals/scenario-approval.gql.d.ts +7 -0
- package/lib/scenario/approvals/scenario-approval.types.d.ts +63 -0
- package/lib/scenario/approvals/scenario-approver.service.d.ts +32 -0
- package/lib/scenario/claimants/scenario-claimant.gql.d.ts +5 -0
- package/lib/scenario/claimants/scenario-claimant.service.d.ts +17 -0
- package/lib/scenario/claimants/scenario-claimant.types.d.ts +18 -0
- package/lib/scenario/receivers/scenario-receiver.gql.d.ts +8 -0
- package/lib/scenario/receivers/scenario-receiver.service.d.ts +30 -0
- package/lib/scenario/receivers/scenario-receiver.types.d.ts +54 -0
- package/lib/scenario/scenario-setup.service.d.ts +22 -0
- package/lib/scenario/scenario.gql.d.ts +34 -0
- package/lib/scenario/scenario.service.d.ts +58 -0
- package/lib/scenario/scenario.types.d.ts +217 -0
- package/lib/search/search.gql.d.ts +1 -0
- package/lib/search/search.service.d.ts +25 -0
- package/lib/search/search.types.d.ts +20 -0
- package/lib/trusted-parties/tp-password-reset-request.service.d.ts +20 -0
- package/lib/trusted-parties/tp-password-reset-user.service.d.ts +41 -0
- package/lib/trusted-parties/tp-password-reset.gql.d.ts +218 -0
- package/lib/trusted-parties/tp-password-reset.service.d.ts +131 -0
- package/lib/trusted-parties/trusted-party.gql.d.ts +9 -0
- package/lib/trusted-parties/trusted-party.service.d.ts +44 -0
- package/lib/trusted-parties/trusted-party.types.d.ts +102 -0
- package/lib/trusted-parties/trusted-party2.gql.d.ts +79 -0
- package/lib/trusted-parties/trusted-party2.service.d.ts +114 -0
- package/lib/users/profile-details.service.d.ts +21 -0
- package/lib/users/profile.gql.d.ts +11 -0
- package/lib/users/profile.service.d.ts +35 -0
- package/lib/users/profile.types.d.ts +96 -0
- package/lib/users/user.gql.d.ts +9 -0
- package/lib/users/user.service.d.ts +12 -0
- package/lib/users/user.types.d.ts +23 -0
- package/lifeready-core.d.ts +9 -0
- package/lifeready-core.metadata.json +1 -0
- package/package.json +29 -0
- 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":";AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACnD,OAAO,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAC;AAC/D,OAAO,EAAE,iBAAiB,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;AAC5E,OAAO,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAC;AAC5D,OAAO,EACL,uBAAuB,EAMvB,uBAAuB,GACxB,MAAM,6BAA6B,CAAC;AAErC,OAAO,EAAE,iBAAiB,EAAE,MAAM,mCAAmC,CAAC;AACtE,OAAO,EAAE,+BAA+B,EAAE,MAAM,uCAAuC,CAAC;;;;;AAExF,SAAS,UAAU,CAAC,OAAyB,EAAE,GAAW;IACxD,uCACK,OAAO,KACV,IAAI,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC,IAC5B;AACJ,CAAC;IAQY,qBAAqB,SAArB,qBAAqB;IAIhC,YACU,MAAc,EACd,UAAsB,EACtB,MAA+B,EAC/B,aAA8C;QAH9C,WAAM,GAAN,MAAM,CAAQ;QACd,eAAU,GAAV,UAAU,CAAY;QACtB,WAAM,GAAN,MAAM,CAAyB;QAC/B,kBAAa,GAAb,aAAa,CAAiC;QAP/C,aAAQ,GAAG,YAAY,CAAC;QACzB,eAAU,GAAyC,EAAE,CAAC;QAQ5D,IAAI,CAAC,iBAAiB,CACpB,eAAe,EACf,MAAM,CAAC,MAAM,CAAC;YACZ,MAAM,CAAC,sBAAsB,CAAC;gBAC5B,cAAc,EAAE,WAAW;aAC5B,CAAC;YACF,MAAM,CAAC,uBAAuB,CAAC;gBAC7B,eAAe,EAAE,YAAY;aAC9B,CAAC;SACH,CAAC,CACH,CAAC;QACF,IAAI,CAAC,iBAAiB,CACpB,eAAe,EACf,MAAM,CAAC,MAAM,CAAC;YACZ,MAAM,CAAC,sBAAsB,CAAC;gBAC5B,cAAc,EAAE,WAAW;aAC5B,CAAC;YACF,MAAM,CAAC,uBAAuB,CAAC;gBAC7B,eAAe,EAAE,YAAY;aAC9B,CAAC;SACH,CAAC,CACH,CAAC;QACF,IAAI,CAAC,iBAAiB,CACpB,iBAAiB,EACjB,MAAM,CAAC,uBAAuB,CAAC;YAC7B,eAAe,EAAE,YAAY;SAC9B,CAAC,CACH,CAAC;QACF,IAAI,CAAC,iBAAiB,CACpB,uBAAuB,EACvB,MAAM,CAAC,MAAM,CAAC;YACZ,MAAM,CAAC,sBAAsB,CAAC;gBAC5B,cAAc,EAAE,gBAAgB;aACjC,CAAC;YACF,MAAM,CAAC,uBAAuB,CAAC;gBAC7B,eAAe,EAAE,iBAAiB;gBAClC,QAAQ,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE;oBACtB,OAAO,KAAK,CAAC,QAAQ,CAAC,EAAE,CAAC;gBAC3B,CAAC;aACF,CAAC;YACF,MAAM,CAAC,uBAAuB,CAAC;gBAC7B,eAAe,EAAE,oBAAoB;gBACrC,QAAQ,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE;oBACtB,OAAO,KAAK,CAAC,WAAW,CAAC,EAAE,CAAC;gBAC9B,CAAC;aACF,CAAC;YACF,MAAM,CAAC,uBAAuB,CAAC;gBAC7B,eAAe,EAAE,kBAAkB;gBACnC,QAAQ,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,KAAK,CAAC,SAAS,CAAC,EAAE;aAC5C,CAAC;SACH,CAAC,CACH,CAAC;QACF,IAAI,CAAC,iBAAiB,CACpB,qBAAqB,EACrB,IAAI,CAAC,aAAa,CAAC,gCAAgC,EAAE,CACtD,CAAC;QACF,IAAI,CAAC,iBAAiB,CACpB,2BAA2B,EAC3B,MAAM,CAAC,MAAM,CAAC;YACZ,MAAM,CAAC,uBAAuB,CAAC;gBAC7B,eAAe,EAAE,0BAA0B;gBAC3C,QAAQ,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,KAAK,CAAC,SAAS,CAAC,EAAE;aAC5C,CAAC;YACF,MAAM,CAAC,uBAAuB,CAAC;gBAC7B,eAAe,EAAE,gCAAgC;gBACjD,QAAQ,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,KAAK,CAAC,SAAS,CAAC,EAAE;aAC5C,CAAC;SACH,CAAC,CACH,CAAC;QACF,IAAI,CAAC,iBAAiB,CACpB,0BAA0B,EAC1B,MAAM,CAAC,MAAM,CAAC;YACZ,MAAM,CAAC,uBAAuB,CAAC;gBAC7B,eAAe,EAAE,kBAAkB;gBACnC,QAAQ,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,KAAK,CAAC,SAAS,CAAC,EAAE;aAC5C,CAAC;SACH,CAAC,CACH,CAAC;IACJ,CAAC;IAEK,YAAY,CAChB,MAA8B,EAC9B,OAAyB;;YAEzB,OAAO,mCACF,uBAAuB,GACvB,OAAO,CACX,CAAC;YAEF,+CAA+C;YAC/C,MAAM,GAAG,GAAG,iBAAiB,CAAC,MAAM,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE,CACnD,IAAI,CAAC,YAAY,CAAC;gBAChB,KAAK;gBACL,OAAO,EAAE;oBACP,IAAI,EAAE,CAAC,GAAG,CAAC;oBACX,eAAe,EAAE,IAAI;iBACtB;gBACD,OAAO;aACR,CAAC,CACH,CAAC;YACF,OAAO,GAAG,CAAC;QACb,CAAC;KAAA;IAED,wCAAwC;IACxC,+EAA+E;IAC/E,oGAAoG;IACpG,wFAAwF;IACxF,+BAA+B;IACjB,YAAY,CAAC,EACzB,KAAK,EACL,OAAO,EACP,OAAO,GACiB;;YACxB,IAAI,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,IAAI,EAAE;gBACf,MAAM,IAAI,mBAAmB,CAC3B,6CAA6C,CAC9C,CAAC;aACH;YAED,IAAI,KAAK,IAAI,IAAI,EAAE;gBACjB,OAAO,IAAI,CAAC;aACb;YAED,MAAM,SAAS,GAA4B;gBACzC,KAAK;gBACL,OAAO,kCACF,OAAO;oBACV,oEAAoE;oBACpE,eAAe,EAAE,IAAI,GACtB;gBACD,OAAO;aACR,CAAC;YAEF,8FAA8F;YAC9F,oFAAoF;YACpF,IAAI,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE;gBACxB,4BAA4B;gBAC5B,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;gBACxD,IAAI,SAAS,EAAE;oBACb,uCAAuC;oBACvC,KAAK,GAAG,SAAS,CAAC,SAAS,CAAC,CAAC;iBAC9B;gBAED,MAAM,eAAe,GAAG,CAAC,UAAU,EAAE,EAAE;oBACrC,IACE,OAAO,CAAC,eAAe;wBACvB,UAAU,KAAK,IAAI;wBACnB,OAAO,UAAU,KAAK,QAAQ,EAC9B;wBACA,OAAO,iBAAiB,CAAC,UAAU,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE,CAC9C,IAAI,CAAC,YAAY,CAAC;4BAChB,KAAK,EAAE,CAAC;4BACR,OAAO,EAAE,UAAU,CAAC,OAAO,EAAE,GAAG,CAAC;4BACjC,OAAO;yBACR,CAAC,CACH,CAAC;qBACH;yBAAM;wBACL,OAAO,UAAU,CAAC;qBACnB;gBACH,CAAC,CAAC;gBAEF,mCAAmC;gBACnC,IAAI,KAAK,CAAC,IAAI,EAAE;oBACd,4BAA4B;oBAC5B,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,aAAa,EAAE,EAAE;wBACnC,OAAO,eAAe,CAAC,aAAa,CAAC,CAAC;oBACxC,CAAC,CAAC,CAAC;iBACJ;qBAAM;oBACL,4BAA4B;oBAC5B,KAAK,GAAG,eAAe,CAAC,KAAK,CAAC,CAAC;iBAChC;aACF;iBAAM;gBACL,mCAAmC;gBACnC,IAAI,OAAO,CAAC,eAAe,EAAE;oBAC3B,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;wBACxB,KAAK,GAAG,kBAAkB,CACvB,KAAoB,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CACjC,IAAI,CAAC,YAAY,CAAC;4BAChB,KAAK,EAAE,CAAC;4BACR,OAAO,EAAE,UAAU,CAAC,OAAO,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAC;4BAC1C,OAAO;yBACR,CAAC,CACH,CACF,CAAC;qBACH;iBACF;aACF;YAED,OAAO,KAAK,CAAC;QACf,CAAC;KAAA;IAEO,iBAAiB,CAAC,IAAY,EAAE,SAA4B;QAClE,IAAI,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE;YACzB,MAAM,IAAI,mBAAmB,CAC3B,uBAAuB,IAAI,kBAAkB,CAC9C,CAAC;SACH;QACD,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,GAAG,SAAS,CAAC;IACpC,CAAC;CACF,CAAA;;;YApNA,UAAU,SAAC;gBACV,UAAU,EAAE,MAAM;aACnB;;;YA7BoB,MAAM;YAGlB,UAAU;YAEjB,uBAAuB;YAUhB,+BAA+B;;AAe3B,qBAAqB;IANjC,iBAAiB,CAAC;QACjB,UAAU,EAAE,QAAQ;KACrB,CAAC;GAIW,qBAAqB,CAiNjC;SAjNY,qBAAqB","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":"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","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=
|