@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,300 @@
|
|
|
1
|
+
import { __awaiter, __rest } from "tslib";
|
|
2
|
+
import { Injectable } from '@angular/core';
|
|
3
|
+
import { LrApolloService } from '../../api/lr-apollo.service';
|
|
4
|
+
import { EncryptionService } from '../../cryptography/encryption.service';
|
|
5
|
+
import { KeyFactoryService } from '../../cryptography/key-factory.service';
|
|
6
|
+
import { KeyGraphService } from '../../cryptography/key-graph.service';
|
|
7
|
+
import { KeyMetaService } from '../../cryptography/key-meta.service';
|
|
8
|
+
import * as slip from '../../cryptography/slip39.service';
|
|
9
|
+
import { TrustedPartyService } from '../../trusted-parties/trusted-party.service';
|
|
10
|
+
import { CreateScenarioApproverAssemblyMutation, DeleteScenarioApproverAssemblyMutation, GetScenarioApproverQuery, UpdateScenarioApproverAssemblyMutation, UpdateScenarioApproverMutation, } from './scenario-approval.gql';
|
|
11
|
+
import * as i0 from "@angular/core";
|
|
12
|
+
import * as i1 from "../../api/lr-apollo.service";
|
|
13
|
+
import * as i2 from "../../cryptography/key-factory.service";
|
|
14
|
+
import * as i3 from "../../cryptography/key-meta.service";
|
|
15
|
+
import * as i4 from "../../cryptography/key-graph.service";
|
|
16
|
+
import * as i5 from "../../cryptography/slip39.service";
|
|
17
|
+
import * as i6 from "../../cryptography/encryption.service";
|
|
18
|
+
import * as i7 from "../../trusted-parties/trusted-party.service";
|
|
19
|
+
export class ScenarioApproverService {
|
|
20
|
+
constructor(lrApollo, keyFactory, keyMetaService, keyGraph, slip39Service, encryptionService, trustedPartyService) {
|
|
21
|
+
this.lrApollo = lrApollo;
|
|
22
|
+
this.keyFactory = keyFactory;
|
|
23
|
+
this.keyMetaService = keyMetaService;
|
|
24
|
+
this.keyGraph = keyGraph;
|
|
25
|
+
this.slip39Service = slip39Service;
|
|
26
|
+
this.encryptionService = encryptionService;
|
|
27
|
+
this.trustedPartyService = trustedPartyService;
|
|
28
|
+
}
|
|
29
|
+
getApprover(approverId) {
|
|
30
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
31
|
+
const { scenarioApprover } = yield this.lrApollo.query({
|
|
32
|
+
query: GetScenarioApproverQuery,
|
|
33
|
+
variables: {
|
|
34
|
+
id: approverId,
|
|
35
|
+
},
|
|
36
|
+
});
|
|
37
|
+
return this.mapApprover(scenarioApprover);
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
mapApproverGroup(group) {
|
|
41
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
42
|
+
const { name } = yield this.keyGraph.decryptFromString(group.assemblyKey.id, group.subAssemblyCipherData);
|
|
43
|
+
return {
|
|
44
|
+
id: group.id,
|
|
45
|
+
keyId: group.assemblyKey.id,
|
|
46
|
+
name,
|
|
47
|
+
quorum: group.quorum,
|
|
48
|
+
singleReject: group.singleReject,
|
|
49
|
+
approvers: yield Promise.all(group.approvers.edges.map((x) => this.mapApprover(x.node))),
|
|
50
|
+
};
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
mapApprover(approver) {
|
|
54
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
55
|
+
const { message } = yield this.keyGraph.decryptFromString(approver.sharedKey.id, approver.sharedCipherData);
|
|
56
|
+
return {
|
|
57
|
+
id: approver.id,
|
|
58
|
+
keyId: approver.sharedKey.id,
|
|
59
|
+
trustedParty: yield this.trustedPartyService.mapTrustedParty(approver.tp),
|
|
60
|
+
message,
|
|
61
|
+
};
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
updateApprover(approver) {
|
|
65
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
66
|
+
const sharedCipherData = yield this.keyGraph.encryptToString(approver.keyId, approver.plainSharedCipherData);
|
|
67
|
+
yield this.lrApollo.mutate({
|
|
68
|
+
mutation: UpdateScenarioApproverMutation,
|
|
69
|
+
variables: {
|
|
70
|
+
input: {
|
|
71
|
+
approverId: approver.approverId,
|
|
72
|
+
sharedKeyId: approver.keyId,
|
|
73
|
+
sharedCipherData,
|
|
74
|
+
sharedCipherApprovalData: '',
|
|
75
|
+
},
|
|
76
|
+
},
|
|
77
|
+
});
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
createScenarioApproverAssembly(input) {
|
|
81
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
82
|
+
const assemblyKey = yield this.keyFactory.createKey();
|
|
83
|
+
const subjectKeyWrappedAssemblyKey = yield this.keyGraph.encryptToString(input.keyId, assemblyKey.toJSON(true));
|
|
84
|
+
const assemblyCipherData = input.plainAssemblyCipherData
|
|
85
|
+
? yield this.keyGraph.encryptToString(assemblyKey, input.plainAssemblyCipherData)
|
|
86
|
+
: '';
|
|
87
|
+
const { createScenarioApproverAssembly } = yield this.lrApollo.mutate({
|
|
88
|
+
mutation: CreateScenarioApproverAssemblyMutation,
|
|
89
|
+
variables: {
|
|
90
|
+
input: {
|
|
91
|
+
scenarioId: input.scenarioId,
|
|
92
|
+
singleReject: input.singleReject,
|
|
93
|
+
quorum: input.quorum,
|
|
94
|
+
subjectKeyId: input.keyId,
|
|
95
|
+
subjectKeyWrappedAssemblyKey,
|
|
96
|
+
assemblyCipherData,
|
|
97
|
+
createSubAssemblies: (yield this.mapApprovalGroups(input.approvalGroups, input.quorum, assemblyKey)).map((x) => {
|
|
98
|
+
const { updateApprovers, deleteApprovers } = x, subAssembly = __rest(x, ["updateApprovers", "deleteApprovers"]);
|
|
99
|
+
return subAssembly;
|
|
100
|
+
}),
|
|
101
|
+
updateReceivers: yield this.rewrapReceivers(assemblyKey, input.event, input.receivers),
|
|
102
|
+
},
|
|
103
|
+
},
|
|
104
|
+
});
|
|
105
|
+
return createScenarioApproverAssembly.scenario.approverAssembly.assemblyKey
|
|
106
|
+
.id;
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
updateScenarioApproverAssembly(input) {
|
|
110
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
111
|
+
const assemblyKey = yield this.keyGraph.getKey(input.assemblyKeyId);
|
|
112
|
+
const assemblyCipherData = input.plainAssemblyCipherData
|
|
113
|
+
? yield this.keyGraph.encryptToString(assemblyKey.jwk, input.plainAssemblyCipherData)
|
|
114
|
+
: '';
|
|
115
|
+
const approvalGroups = yield this.mapApprovalGroups(input.approvalGroups, input.quorum, assemblyKey.jwk);
|
|
116
|
+
yield this.lrApollo.mutate({
|
|
117
|
+
mutation: UpdateScenarioApproverAssemblyMutation,
|
|
118
|
+
variables: {
|
|
119
|
+
input: {
|
|
120
|
+
scenarioId: input.scenarioId,
|
|
121
|
+
singleReject: input.singleReject,
|
|
122
|
+
quorum: input.quorum,
|
|
123
|
+
assemblyKeyId: assemblyKey.id,
|
|
124
|
+
assemblyCipherData,
|
|
125
|
+
createSubAssemblies: approvalGroups
|
|
126
|
+
.filter((x) => !x.subAssemblyId)
|
|
127
|
+
.map((x) => {
|
|
128
|
+
const { updateApprovers, deleteApprovers } = x, subAssembly = __rest(x, ["updateApprovers", "deleteApprovers"]);
|
|
129
|
+
return subAssembly;
|
|
130
|
+
}),
|
|
131
|
+
updateSubAssemblies: approvalGroups.filter((x) => x.subAssemblyId),
|
|
132
|
+
deleteSubAssemblies: input.deletedGroupIds,
|
|
133
|
+
},
|
|
134
|
+
},
|
|
135
|
+
});
|
|
136
|
+
});
|
|
137
|
+
}
|
|
138
|
+
deleteScenarioApproverAssembly(scenarioId, event, receivers) {
|
|
139
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
140
|
+
yield this.lrApollo.mutate({
|
|
141
|
+
mutation: DeleteScenarioApproverAssemblyMutation,
|
|
142
|
+
variables: {
|
|
143
|
+
input: {
|
|
144
|
+
scenarioId,
|
|
145
|
+
updateReceivers: yield this.rewrapReceivers(null, event, receivers),
|
|
146
|
+
},
|
|
147
|
+
},
|
|
148
|
+
});
|
|
149
|
+
});
|
|
150
|
+
}
|
|
151
|
+
rewrapReceivers(assemblyKey, event, receivers) {
|
|
152
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
153
|
+
if (!receivers || !receivers.length) {
|
|
154
|
+
return [];
|
|
155
|
+
}
|
|
156
|
+
return yield Promise.all(receivers.map((receiver) => __awaiter(this, void 0, void 0, function* () {
|
|
157
|
+
const sharedKey = yield this.keyGraph.getKey(receiver.keyId);
|
|
158
|
+
const prepareReceiverItem = (item, itemKeyId) => __awaiter(this, void 0, void 0, function* () {
|
|
159
|
+
const itemKey = yield this.keyGraph.getKey(itemKeyId);
|
|
160
|
+
let wrappedItemKey = yield this.keyGraph.encryptToString(sharedKey.jwk, itemKey.jwk.toJSON(true));
|
|
161
|
+
if (assemblyKey) {
|
|
162
|
+
wrappedItemKey = yield this.keyGraph.encryptToString(assemblyKey, wrappedItemKey);
|
|
163
|
+
}
|
|
164
|
+
return {
|
|
165
|
+
accessRole: item.accessLevel,
|
|
166
|
+
sharedKeyId: sharedKey.id,
|
|
167
|
+
sharedCipherData: '',
|
|
168
|
+
wrappedItemKey,
|
|
169
|
+
};
|
|
170
|
+
});
|
|
171
|
+
// For each receiver-directory
|
|
172
|
+
const receiverDirectories = yield Promise.all([
|
|
173
|
+
...receiver.categories.map((x) => __awaiter(this, void 0, void 0, function* () {
|
|
174
|
+
return (Object.assign(Object.assign({}, (yield prepareReceiverItem(x, x.category.keyId))), { receiverDirectoryId: x.id }));
|
|
175
|
+
})),
|
|
176
|
+
...receiver.records.map((x) => __awaiter(this, void 0, void 0, function* () {
|
|
177
|
+
return (Object.assign(Object.assign({}, (yield prepareReceiverItem(x, x.record.keyId))), { receiverDirectoryId: x.id }));
|
|
178
|
+
})),
|
|
179
|
+
]);
|
|
180
|
+
return {
|
|
181
|
+
receiverId: receiver.id,
|
|
182
|
+
sharedKeyId: receiver.keyId,
|
|
183
|
+
receiverDirectories,
|
|
184
|
+
receiverFiles: [],
|
|
185
|
+
sharedCipherData: yield this.keyGraph.encryptToString(sharedKey.jwk, {
|
|
186
|
+
event,
|
|
187
|
+
message: receiver.message,
|
|
188
|
+
}),
|
|
189
|
+
};
|
|
190
|
+
})));
|
|
191
|
+
});
|
|
192
|
+
}
|
|
193
|
+
mapApprovalGroups(approvalGroups, quorum, assemblyKey) {
|
|
194
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
195
|
+
const slipAssembly = yield this.createSlipAssembly(quorum, approvalGroups, assemblyKey.toJSON(true).k);
|
|
196
|
+
return yield Promise.all(approvalGroups.map((x, index) => this.mapApprovalGroup(x, slipAssembly.subAssemblies[index], assemblyKey)));
|
|
197
|
+
});
|
|
198
|
+
}
|
|
199
|
+
mapApprovalGroup(approvalGroup, subAssembly, assemblyKey) {
|
|
200
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
201
|
+
const approvers = yield this.mapApprovers(approvalGroup.approvers, approvalGroup.quorum, subAssembly, assemblyKey);
|
|
202
|
+
return {
|
|
203
|
+
subAssemblyId: approvalGroup.subAssemblyId,
|
|
204
|
+
singleReject: approvalGroup.singleReject,
|
|
205
|
+
quorum: approvalGroup.quorum,
|
|
206
|
+
subAssemblyCipherData: yield this.keyGraph.encryptToString(assemblyKey, approvalGroup.plainSubAssemblyCipherData),
|
|
207
|
+
createApprovers: approvers.filter((x) => !x.approverId),
|
|
208
|
+
updateApprovers: approvers.filter((x) => x.approverId),
|
|
209
|
+
deleteApprovers: approvalGroup.deletedApproverIds || [],
|
|
210
|
+
};
|
|
211
|
+
});
|
|
212
|
+
}
|
|
213
|
+
mapApprovers(approvers, quorum, subAssembly, assemblyKey) {
|
|
214
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
215
|
+
const _a = assemblyKey.toJSON(true), { k: rawAssemblyKey } = _a, assemblyKeyParams = __rest(_a, ["k"]);
|
|
216
|
+
let shareIdx = 0;
|
|
217
|
+
const nextPartialAssemblyKey = (sharedKeyJwk) => __awaiter(this, void 0, void 0, function* () {
|
|
218
|
+
const share = subAssembly.shares[shareIdx];
|
|
219
|
+
// If quorum is 1, then using the same share for every member.
|
|
220
|
+
if (quorum !== 1) {
|
|
221
|
+
++shareIdx;
|
|
222
|
+
}
|
|
223
|
+
const partialAssemblyKey = {
|
|
224
|
+
slip39: {
|
|
225
|
+
share,
|
|
226
|
+
subAssembly: {
|
|
227
|
+
quorum,
|
|
228
|
+
size: approvers.length,
|
|
229
|
+
},
|
|
230
|
+
},
|
|
231
|
+
assemblyKeyParams,
|
|
232
|
+
};
|
|
233
|
+
return this.keyGraph.encryptToString(sharedKeyJwk, partialAssemblyKey);
|
|
234
|
+
});
|
|
235
|
+
return yield Promise.all(approvers.map((x) => __awaiter(this, void 0, void 0, function* () {
|
|
236
|
+
if (x.approverId) {
|
|
237
|
+
const sharedKey = yield this.keyGraph.getKey(x.keyId);
|
|
238
|
+
const sharedCipherData = yield this.keyGraph.encryptToString(x.keyId, x.plainSharedCipherData);
|
|
239
|
+
const sharedCipherApprovalData = yield this.keyGraph.encryptToString(x.keyId, x.approvalData);
|
|
240
|
+
return {
|
|
241
|
+
approverId: x.approverId,
|
|
242
|
+
sharedKeyId: x.keyId,
|
|
243
|
+
sharedCipherData: sharedCipherData || '',
|
|
244
|
+
sharedCipherApprovalData: sharedCipherApprovalData || '',
|
|
245
|
+
sharedCipherPartialAssemblyKey: yield nextPartialAssemblyKey(sharedKey.jwk),
|
|
246
|
+
};
|
|
247
|
+
}
|
|
248
|
+
else {
|
|
249
|
+
const wrappedContent = yield this.keyMetaService.wrapContentWithKey(x.plainSharedCipherData, x.trustedPartySharedKeyId);
|
|
250
|
+
return {
|
|
251
|
+
tpId: x.trustedPartyId,
|
|
252
|
+
tpSharedKeyId: x.trustedPartySharedKeyId,
|
|
253
|
+
tpSharedKeyWrappedSharedKey: wrappedContent.rootKey.wrappedKey,
|
|
254
|
+
sharedCipherData: wrappedContent.cipherMeta,
|
|
255
|
+
sharedCipherApprovalData: '',
|
|
256
|
+
sharedCipherPartialAssemblyKey: yield nextPartialAssemblyKey(wrappedContent.key),
|
|
257
|
+
};
|
|
258
|
+
}
|
|
259
|
+
})));
|
|
260
|
+
});
|
|
261
|
+
}
|
|
262
|
+
// Split assembly key between all existing approvers.
|
|
263
|
+
createSlipAssembly(quorum, approvalGroups, rawAssemblyKey) {
|
|
264
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
265
|
+
const slipAssembly = new slip.Assembly(quorum);
|
|
266
|
+
approvalGroups.forEach((x, index) => {
|
|
267
|
+
let approverCount = x.approvers.length;
|
|
268
|
+
// slip39 restricts quorum == 1 to have only 1 member. So we just share the same
|
|
269
|
+
// partial key for all sub assembly members.
|
|
270
|
+
if (x.quorum === 1) {
|
|
271
|
+
approverCount = 1;
|
|
272
|
+
}
|
|
273
|
+
slipAssembly.addSubAssembly(new slip.SubAssembly(index, x.quorum, approverCount));
|
|
274
|
+
});
|
|
275
|
+
// Is there enough sub assemblies to meet quorum
|
|
276
|
+
if (slipAssembly.subAssemblies.length < quorum) {
|
|
277
|
+
return null;
|
|
278
|
+
}
|
|
279
|
+
yield this.slip39Service.generateShares(rawAssemblyKey, ScenarioApproverService.SLIP39_PASSPHRASE, slipAssembly);
|
|
280
|
+
return slipAssembly;
|
|
281
|
+
});
|
|
282
|
+
}
|
|
283
|
+
}
|
|
284
|
+
ScenarioApproverService.SLIP39_PASSPHRASE = 'lifeready';
|
|
285
|
+
ScenarioApproverService.ɵprov = i0.ɵɵdefineInjectable({ factory: function ScenarioApproverService_Factory() { return new ScenarioApproverService(i0.ɵɵinject(i1.LrApolloService), i0.ɵɵinject(i2.KeyFactoryService), i0.ɵɵinject(i3.KeyMetaService), i0.ɵɵinject(i4.KeyGraphService), i0.ɵɵinject(i5.Slip39Service), i0.ɵɵinject(i6.EncryptionService), i0.ɵɵinject(i7.TrustedPartyService)); }, token: ScenarioApproverService, providedIn: "root" });
|
|
286
|
+
ScenarioApproverService.decorators = [
|
|
287
|
+
{ type: Injectable, args: [{
|
|
288
|
+
providedIn: 'root',
|
|
289
|
+
},] }
|
|
290
|
+
];
|
|
291
|
+
ScenarioApproverService.ctorParameters = () => [
|
|
292
|
+
{ type: LrApolloService },
|
|
293
|
+
{ type: KeyFactoryService },
|
|
294
|
+
{ type: KeyMetaService },
|
|
295
|
+
{ type: KeyGraphService },
|
|
296
|
+
{ type: slip.Slip39Service },
|
|
297
|
+
{ type: EncryptionService },
|
|
298
|
+
{ type: TrustedPartyService }
|
|
299
|
+
];
|
|
300
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NlbmFyaW8tYXBwcm92ZXIuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiJDOi9Qcm9qZWN0cy90ZXN0L3Byb2plY3RzL2NvcmUvc3JjLyIsInNvdXJjZXMiOlsibGliL3NjZW5hcmlvL2FwcHJvdmFscy9zY2VuYXJpby1hcHByb3Zlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTNDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUM5RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUMxRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx3Q0FBd0MsQ0FBQztBQUMzRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDdkUsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQ3JFLE9BQU8sS0FBSyxJQUFJLE1BQU0sbUNBQW1DLENBQUM7QUFDMUQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sNkNBQTZDLENBQUM7QUFPbEYsT0FBTyxFQUNMLHNDQUFzQyxFQUN0QyxzQ0FBc0MsRUFDdEMsd0JBQXdCLEVBQ3hCLHNDQUFzQyxFQUN0Qyw4QkFBOEIsR0FDL0IsTUFBTSx5QkFBeUIsQ0FBQzs7Ozs7Ozs7O0FBYWpDLE1BQU0sT0FBTyx1QkFBdUI7SUFHbEMsWUFDVSxRQUF5QixFQUN6QixVQUE2QixFQUM3QixjQUE4QixFQUM5QixRQUF5QixFQUN6QixhQUFpQyxFQUNqQyxpQkFBb0MsRUFDcEMsbUJBQXdDO1FBTnhDLGFBQVEsR0FBUixRQUFRLENBQWlCO1FBQ3pCLGVBQVUsR0FBVixVQUFVLENBQW1CO1FBQzdCLG1CQUFjLEdBQWQsY0FBYyxDQUFnQjtRQUM5QixhQUFRLEdBQVIsUUFBUSxDQUFpQjtRQUN6QixrQkFBYSxHQUFiLGFBQWEsQ0FBb0I7UUFDakMsc0JB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QUN2QyxrQkFBa0IsQ0FDOUIsTUFBYyxFQUNkLGNBQTZDLEVBQzdDLGNBQXNCOztZQUV0QixNQUFNLFlBQVksR0FBRyxJQUFJLElBQUksQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDLENBQUM7WUFFL0MsY0FBYyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsRUFBRSxLQUFLLEVBQUUsRUFBRTtnQkFDbEMsSUFBSSxhQUFhLEdBQUcsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUM7Z0JBRXZDLGdGQUFnRjtnQkFDaEYsNENBQTRDO2dCQUM1QyxJQUFJLENBQUMsQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFO29CQUNsQixhQUFhLEdBQUcsQ0FBQyxDQUFDO2lCQUNuQjtnQkFDRCxZQUFZLENBQUMsY0FBYyxDQUN6QixJQUFJLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQyxNQUFNLEVBQUUsYUFBYSxDQUFDLENBQ3JELENBQUM7WUFDSixDQUFDLENBQUMsQ0FBQztZQUNILGdEQUFnRDtZQUNoRCxJQUFJLFlBQVksQ0FBQyxhQUFhLENBQUMsTUFBTSxHQUFHLE1BQU0sRUFBRTtnQkFDOUMsT0FBTyxJQUFJLENBQUM7YUFDYjtZQUNELE1BQU0sSUFBSSxDQUFDLGFBQWEsQ0FBQyxjQUFjLENBQ3JDLGNBQWMsRUFDZCx1QkFBdUIsQ0FBQyxpQkFBaUIsRUFDekMsWUFBWSxDQUNiLENBQUM7WUFDRixPQUFPLFlBQVksQ0FBQztRQUN0QixDQUFDO0tBQUE7O0FBallhLHlDQUFpQixHQUFHLFdBQVcsQ0FBQzs7O1lBSi9DLFVBQVUsU0FBQztnQkFDVixVQUFVLEVBQUUsTUFBTTthQUNuQjs7O1lBL0JRLGVBQWU7WUFFZixpQkFBaUI7WUFFakIsY0FBYztZQURkLGVBQWU7WUFFWixJQUFJLENBbUNnQixhQUFhO1lBdkNwQyxpQkFBaUI7WUFLakIsbUJBQW1CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBKV0sgfSBmcm9tICdub2RlLWpvc2UnO1xyXG5pbXBvcnQgeyBMckFwb2xsb1NlcnZpY2UgfSBmcm9tICcuLi8uLi9hcGkvbHItYXBvbGxvLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBFbmNyeXB0aW9uU2VydmljZSB9IGZyb20gJy4uLy4uL2NyeXB0b2dyYXBoeS9lbmNyeXB0aW9uLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBLZXlGYWN0b3J5U2VydmljZSB9IGZyb20gJy4uLy4uL2NyeXB0b2dyYXBoeS9rZXktZmFjdG9yeS5zZXJ2aWNlJztcclxuaW1wb3J0IHsgS2V5R3JhcGhTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vY3J5cHRvZ3JhcGh5L2tleS1ncmFwaC5zZXJ2aWNlJztcclxuaW1wb3J0IHsgS2V5TWV0YVNlcnZpY2UgfSBmcm9tICcuLi8uLi9jcnlwdG9ncmFwaHkva2V5LW1ldGEuc2VydmljZSc7XHJcbmltcG9ydCAqIGFzIHNsaXAgZnJvbSAnLi4vLi4vY3J5cHRvZ3JhcGh5L3NsaXAzOS5zZXJ2aWNlJztcclxuaW1wb3J0IHsgVHJ1c3RlZFBhcnR5U2VydmljZSB9IGZyb20gJy4uLy4uL3RydXN0ZWQtcGFydGllcy90cnVzdGVkLXBhcnR5LnNlcnZpY2UnO1xyXG5pbXBvcnQge1xyXG4gIFJlY2VpdmVyLFxyXG4gIFJlY2VpdmVyQ2F0ZWdvcnksXHJcbiAgUmVjZWl2ZXJSZWNvcmQsXHJcbn0gZnJvbSAnLi4vcmVjZWl2ZXJzL3NjZW5hcmlvLXJlY2VpdmVyLnR5cGVzJztcclxuaW1wb3J0IHsgUGFydGlhbEFzc2VtYmx5S2V5IH0gZnJvbSAnLi4vc2NlbmFyaW8udHlwZXMnO1xyXG5pbXBvcnQge1xyXG4gIENyZWF0ZVNjZW5hcmlvQXBwcm92ZXJBc3NlbWJseU11dGF0aW9uLFxyXG4gIERlbGV0ZVNjZW5hcmlvQXBwcm92ZXJBc3NlbWJseU11dGF0aW9uLFxyXG4gIEdldFNjZW5hcmlvQXBwcm92ZXJRdWVyeSxcclxuICBVcGRhdGVTY2VuYXJpb0FwcHJvdmVyQXNzZW1ibHlNdXRhdGlvbixcclxuICBVcGRhdGVTY2VuYXJpb0FwcHJvdmVyTXV0YXRpb24sXHJcbn0gZnJvbSAnLi9zY2VuYXJpby1hcHByb3ZhbC5ncWwnO1xyXG5pbXBvcnQge1xyXG4gIEFwcHJvdmFsR3JvdXAsXHJcbiAgQXBwcm92ZXIsXHJcbiAgQ3JlYXRlU2NlbmFyaW9BcHByb3ZhbEdyb3VwcyxcclxuICBVcGRhdGVTY2VuYXJpb0FwcHJvdmFsR3JvdXAsXHJcbiAgVXBkYXRlU2NlbmFyaW9BcHByb3ZhbEdyb3VwcyxcclxuICBVcGRhdGVTY2VuYXJpb0FwcHJvdmVyLFxyXG59IGZyb20gJy4vc2NlbmFyaW8tYXBwcm92YWwudHlwZXMnO1xyXG5cclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46ICdyb290JyxcclxufSlcclxuZXhwb3J0IGNsYXNzIFNjZW5hcmlvQXBwcm92ZXJTZXJ2aWNlIHtcclxuICBwdWJsaWMgc3RhdGljIFNMSVAzOV9QQVNTUEhSQVNFID0gJ2xpZmVyZWFkeSc7XHJcblxyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgcHJpdmF0ZSBsckFwb2xsbzogTHJBcG9sbG9TZXJ2aWNlLFxyXG4gICAgcHJpdmF0ZSBrZXlGYWN0b3J5OiBLZXlGYWN0b3J5U2VydmljZSxcclxuICAgIHByaXZhdGUga2V5TWV0YVNlcnZpY2U6IEtleU1ldGFTZXJ2aWNlLFxyXG4gICAgcHJpdmF0ZSBrZXlHcmFwaDogS2V5R3JhcGhTZXJ2aWNlLFxyXG4gICAgcHJpdmF0ZSBzbGlwMzlTZXJ2aWNlOiBzbGlwLlNsaXAzOVNlcnZpY2UsXHJcbiAgICBwcml2YXRlIGVuY3J5cHRpb25TZXJ2aWNlOiBFbmNyeXB0aW9uU2VydmljZSxcclxuICAgIHByaXZhdGUgdHJ1c3RlZFBhcnR5U2VydmljZTogVHJ1c3RlZFBhcnR5U2VydmljZVxyXG4gICkge31cclxuXHJcbiAgcHVibGljIGFzeW5jIGdldEFwcHJvdmVyKGFwcHJvdmVySWQ6IHN0cmluZyk6IFByb21pc2U8QXBwcm92ZXI+IHtcclxuICAgIGNvbnN0IHsgc2NlbmFyaW9BcHByb3ZlciB9ID0gYXdhaXQgdGhpcy5sckFwb2xsby5xdWVyeTxhbnk+KHtcclxuICAgICAgcXVlcnk6IEdldFNjZW5hcmlvQXBwcm92ZXJRdWVyeSxcclxuICAgICAgdmFyaWFibGVzOiB7XHJcbiAgICAgICAgaWQ6IGFwcHJvdmVySWQsXHJcbiAgICAgIH0sXHJcbiAgICB9KTtcclxuICAgIHJldHVybiB0aGlzLm1hcEFwcHJvdmVyKHNjZW5hcmlvQXBwcm92ZXIpO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGFzeW5jIG1hcEFwcHJvdmVyR3JvdXAoZ3JvdXA6IGFueSk6IFByb21pc2U8QXBwcm92YWxHcm91cD4ge1xyXG4gICAgY29uc3QgeyBuYW1lIH0gPSBhd2FpdCB0aGlzLmtleUdyYXBoLmRlY3J5cHRGcm9tU3RyaW5nPHtcclxuICAgICAgbmFtZTogc3RyaW5nO1xyXG4gICAgfT4oZ3JvdXAuYXNzZW1ibHlLZXkuaWQsIGdyb3VwLnN1YkFzc2VtYmx5Q2lwaGVyRGF0YSk7XHJcblxyXG4gICAgcmV0dXJuIHtcclxuICAgICAgaWQ6IGdyb3VwLmlkLFxyXG4gICAgICBrZXlJZDogZ3JvdXAuYXNzZW1ibHlLZXkuaWQsXHJcbiAgICAgIG5hbWUsXHJcbiAgICAgIHF1b3J1bTogZ3JvdXAucXVvcnVtLFxyXG4gICAgICBzaW5nbGVSZWplY3Q6IGdyb3VwLnNpbmdsZVJlamVjdCxcclxuICAgICAgYXBwcm92ZXJzOiBhd2FpdCBQcm9taXNlLmFsbChcclxuICAgICAgICBncm91cC5hcHByb3ZlcnMuZWRnZXMubWFwKCh4KSA9PiB0aGlzLm1hcEFwcHJvdmVyKHgubm9kZSkpXHJcbiAgICAgICksXHJcbiAgICB9O1xyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSBhc3luYyBtYXBBcHByb3ZlcihhcHByb3ZlcjogYW55KTogUHJvbWlzZTxBcHByb3Zlcj4ge1xyXG4gICAgY29uc3QgeyBtZXNzYWdlIH0gPSBhd2FpdCB0aGlzLmtleUdyYXBoLmRlY3J5cHRGcm9tU3RyaW5nPHtcclxuICAgICAgbWVzc2FnZTogc3RyaW5nO1xyXG4gICAgfT4oYXBwcm92ZXIuc2hhcmVkS2V5LmlkLCBhcHByb3Zlci5zaGFyZWRDaXBoZXJEYXRhKTtcclxuXHJcbiAgICByZXR1cm4ge1xyXG4gICAgICBpZDogYXBwcm92ZXIuaWQsXHJcbiAgICAgIGtleUlkOiBhcHByb3Zlci5zaGFyZWRLZXkuaWQsXHJcbiAgICAgIHRydXN0ZWRQYXJ0eTogYXdhaXQgdGhpcy50cnVzdGVkUGFydHlTZXJ2aWNlLm1hcFRydXN0ZWRQYXJ0eShhcHByb3Zlci50cCksXHJcbiAgICAgIG1lc3NhZ2UsXHJcbiAgICB9O1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGFzeW5jIHVwZGF0ZUFwcHJvdmVyKGFwcHJvdmVyOiBVcGRhdGVTY2VuYXJpb0FwcHJvdmVyKTogUHJvbWlzZTx2b2lkPiB7XHJcbiAgICBjb25zdCBzaGFyZWRDaXBoZXJEYXRhID0gYXdhaXQgdGhpcy5rZXlHcmFwaC5lbmNyeXB0VG9TdHJpbmcoXHJcbiAgICAgIGFwcHJvdmVyLmtleUlkLFxyXG4gICAgICBhcHByb3Zlci5wbGFpblNoYXJlZENpcGhlckRhdGFcclxuICAgICk7XHJcblxyXG4gICAgYXdhaXQgdGhpcy5sckFwb2xsby5tdXRhdGU8YW55Pih7XHJcbiAgICAgIG11dGF0aW9uOiBVcGRhdGVTY2VuYXJpb0FwcHJvdmVyTXV0YXRpb24sXHJcbiAgICAgIHZhcmlhYmxlczoge1xyXG4gICAgICAgIGlucHV0OiB7XHJcbiAgICAgICAgICBhcHByb3ZlcklkOiBhcHByb3Zlci5hcHByb3ZlcklkLFxyXG4gICAgICAgICAgc2hhcmVkS2V5SWQ6IGFwcHJvdmVyLmtleUlkLFxyXG4gICAgICAgICAgc2hhcmVkQ2lwaGVyRGF0YSxcclxuICAgICAgICAgIHNoYXJlZENpcGhlckFwcHJvdmFsRGF0YTogJycsXHJcbiAgICAgICAgfSxcclxuICAgICAgfSxcclxuICAgIH0pO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGFzeW5jIGNyZWF0ZVNjZW5hcmlvQXBwcm92ZXJBc3NlbWJseShcclxuICAgIGlucHV0OiBDcmVhdGVTY2VuYXJpb0FwcHJvdmFsR3JvdXBzXHJcbiAgKTogUHJvbWlzZTxzdHJpbmc+IHtcclxuICAgIGNvbnN0IGFzc2VtYmx5S2V5ID0gYXdhaXQgdGhpcy5rZXlGYWN0b3J5LmNyZWF0ZUtleSgpO1xyXG5cclxuICAgIGNvbnN0IHN1YmplY3RLZXlXcmFwcGVkQXNzZW1ibHlLZXkgPSBhd2FpdCB0aGlzLmtleUdyYXBoLmVuY3J5cHRUb1N0cmluZyhcclxuICAgICAgaW5wdXQua2V5SWQsXHJcbiAgICAgIGFzc2VtYmx5S2V5LnRvSlNPTih0cnVlKVxyXG4gICAgKTtcclxuXHJcbiAgICBjb25zdCBhc3NlbWJseUNpcGhlckRhdGEgPSBpbnB1dC5wbGFpbkFzc2VtYmx5Q2lwaGVyRGF0YVxyXG4gICAgICA/IGF3YWl0IHRoaXMua2V5R3JhcGguZW5jcnlwdFRvU3RyaW5nKFxyXG4gICAgICAgICAgYXNzZW1ibHlLZXksXHJcbiAgICAgICAgICBpbnB1dC5wbGFpbkFzc2VtYmx5Q2lwaGVyRGF0YVxyXG4gICAgICAgIClcclxuICAgICAgOiAnJztcclxuXHJcbiAgICBjb25zdCB7IGNyZWF0ZVNjZW5hcmlvQXBwcm92ZXJBc3NlbWJseSB9ID0gYXdhaXQgdGhpcy5sckFwb2xsby5tdXRhdGU8YW55Pih7XHJcbiAgICAgIG11dGF0aW9uOiBDcmVhdGVTY2VuYXJpb0FwcHJvdmVyQXNzZW1ibHlNdXRhdGlvbixcclxuICAgICAgdmFyaWFibGVzOiB7XHJcbiAgICAgICAgaW5wdXQ6IHtcclxuICAgICAgICAgIHNjZW5hcmlvSWQ6IGlucHV0LnNjZW5hcmlvSWQsXHJcbiAgICAgICAgICBzaW5nbGVSZWplY3Q6IGlucHV0LnNpbmdsZVJlamVjdCxcclxuICAgICAgICAgIHF1b3J1bTogaW5wdXQucXVvcnVtLFxyXG4gICAgICAgICAgc3ViamVjdEtleUlkOiBpbnB1dC5rZXlJZCxcclxuICAgICAgICAgIHN1YmplY3RLZXlXcmFwcGVkQXNzZW1ibHlLZXksXHJcbiAgICAgICAgICBhc3NlbWJseUNpcGhlckRhdGEsXHJcbiAgICAgICAgICBjcmVhdGVTdWJBc3NlbWJsaWVzOiAoXHJcbiAgICAgICAgICAgIGF3YWl0IHRoaXMubWFwQXBwcm92YWxHcm91cHMoXHJcbiAgICAgICAgICAgICAgaW5wdXQuYXBwcm92YWxHcm91cHMsXHJcbiAgICAgICAgICAgICAgaW5wdXQucXVvcnVtLFxyXG4gICAgICAgICAgICAgIGFzc2VtYmx5S2V5XHJcbiAgICAgICAgICAgIClcclxuICAgICAgICAgICkubWFwKCh4KSA9PiB7XHJcbiAgICAgICAgICAgIGNvbnN0IHsgdXBkYXRlQXBwcm92ZXJzLCBkZWxldGVBcHByb3ZlcnMsIC4uLnN1YkFzc2VtYmx5IH0gPSB4O1xyXG4gICAgICAgICAgICByZXR1cm4gc3ViQXNzZW1ibHk7XHJcbiAgICAgICAgICB9KSxcclxuICAgICAgICAgIHVwZGF0ZVJlY2VpdmVyczogYXdhaXQgdGhpcy5yZXdyYXBSZWNlaXZlcnMoXHJcbiAgICAgICAgICAgIGFzc2VtYmx5S2V5LFxyXG4gICAgICAgICAgICBpbnB1dC5ldmVudCxcclxuICAgICAgICAgICAgaW5wdXQucmVjZWl2ZXJzXHJcbiAgICAgICAgICApLFxyXG4gICAgICAgIH0sXHJcbiAgICAgIH0sXHJcbiAgICB9KTtcclxuICAgIHJldHVybiBjcmVhdGVTY2VuYXJpb0FwcHJvdmVyQXNzZW1ibHkuc2NlbmFyaW8uYXBwcm92ZXJBc3NlbWJseS5hc3NlbWJseUtleVxyXG4gICAgICAuaWQ7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgYXN5bmMgdXBkYXRlU2NlbmFyaW9BcHByb3ZlckFzc2VtYmx5KFxyXG4gICAgaW5wdXQ6IFVwZGF0ZVNjZW5hcmlvQXBwcm92YWxHcm91cHNcclxuICApOiBQcm9taXNlPHZvaWQ+IHtcclxuICAgIGNvbnN0IGFzc2VtYmx5S2V5ID0gYXdhaXQgdGhpcy5rZXlHcmFwaC5nZXRLZXkoaW5wdXQuYXNzZW1ibHlLZXlJZCk7XHJcbiAgICBjb25zdCBhc3NlbWJseUNpcGhlckRhdGEgPSBpbnB1dC5wbGFpbkFzc2VtYmx5Q2lwaGVyRGF0YVxyXG4gICAgICA/IGF3YWl0IHRoaXMua2V5R3JhcGguZW5jcnlwdFRvU3RyaW5nKFxyXG4gICAgICAgICAgYXNzZW1ibHlLZXkuandrLFxyXG4gICAgICAgICAgaW5wdXQucGxhaW5Bc3NlbWJseUNpcGhlckRhdGFcclxuICAgICAgICApXHJcbiAgICAgIDogJyc7XHJcblxyXG4gICAgY29uc3QgYXBwcm92YWxHcm91cHMgPSBhd2FpdCB0aGlzLm1hcEFwcHJvdmFsR3JvdXBzKFxyXG4gICAgICBpbnB1dC5hcHByb3ZhbEdyb3VwcyxcclxuICAgICAgaW5wdXQucXVvcnVtLFxyXG4gICAgICBhc3NlbWJseUtleS5qd2tcclxuICAgICk7XHJcblxyXG4gICAgYXdhaXQgdGhpcy5sckFwb2xsby5tdXRhdGU8YW55Pih7XHJcbiAgICAgIG11dGF0aW9uOiBVcGRhdGVTY2VuYXJpb0FwcHJvdmVyQXNzZW1ibHlNdXRhdGlvbixcclxuICAgICAgdmFyaWFibGVzOiB7XHJcbiAgICAgICAgaW5wdXQ6IHtcclxuICAgICAgICAgIHNjZW5hcmlvSWQ6IGlucHV0LnNjZW5hcmlvSWQsXHJcbiAgICAgICAgICBzaW5nbGVSZWplY3Q6IGlucHV0LnNpbmdsZVJlamVjdCxcclxuICAgICAgICAgIHF1b3J1bTogaW5wdXQucXVvcnVtLFxyXG4gICAgICAgICAgYXNzZW1ibHlLZXlJZDogYXNzZW1ibHlLZXkuaWQsXHJcbiAgICAgICAgICBhc3NlbWJseUNpcGhlckRhdGEsXHJcbiAgICAgICAgICBjcmVhdGVTdWJBc3NlbWJsaWVzOiBhcHByb3ZhbEdyb3Vwc1xyXG4gICAgICAgICAgICAuZmlsdGVyKCh4KSA9PiAheC5zdWJBc3NlbWJseUlkKVxyXG4gICAgICAgICAgICAubWFwKCh4KSA9PiB7XHJcbiAgICAgICAgICAgICAgY29uc3QgeyB1cGRhdGVBcHByb3ZlcnMsIGRlbGV0ZUFwcHJvdmVycywgLi4uc3ViQXNzZW1ibHkgfSA9IHg7XHJcbiAgICAgICAgICAgICAgcmV0dXJuIHN1YkFzc2VtYmx5O1xyXG4gICAgICAgICAgICB9KSxcclxuICAgICAgICAgIHVwZGF0ZVN1YkFzc2VtYmxpZXM6IGFwcHJvdmFsR3JvdXBzLmZpbHRlcigoeCkgPT4geC5zdWJBc3NlbWJseUlkKSxcclxuICAgICAgICAgIGRlbGV0ZVN1YkFzc2VtYmxpZXM6IGlucHV0LmRlbGV0ZWRHcm91cElkcyxcclxuICAgICAgICB9LFxyXG4gICAgICB9LFxyXG4gICAgfSk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgYXN5bmMgZGVsZXRlU2NlbmFyaW9BcHByb3ZlckFzc2VtYmx5KFxyXG4gICAgc2NlbmFyaW9JZDogc3RyaW5nLFxyXG4gICAgZXZlbnQ6IHN0cmluZyxcclxuICAgIHJlY2VpdmVyczogUmVjZWl2ZXJbXVxyXG4gICk6IFByb21pc2U8dm9pZD4ge1xyXG4gICAgYXdhaXQgdGhpcy5sckFwb2xsby5tdXRhdGU8YW55Pih7XHJcbiAgICAgIG11dGF0aW9uOiBEZWxldGVTY2VuYXJpb0FwcHJvdmVyQXNzZW1ibHlNdXRhdGlvbixcclxuICAgICAgdmFyaWFibGVzOiB7XHJcbiAgICAgICAgaW5wdXQ6IHtcclxuICAgICAgICAgIHNjZW5hcmlvSWQsXHJcbiAgICAgICAgICB1cGRhdGVSZWNlaXZlcnM6IGF3YWl0IHRoaXMucmV3cmFwUmVjZWl2ZXJzKG51bGwsIGV2ZW50LCByZWNlaXZlcnMpLFxyXG4gICAgICAgIH0sXHJcbiAgICAgIH0sXHJcbiAgICB9KTtcclxuICB9XHJcblxyXG4gIHByaXZhdGUgYXN5bmMgcmV3cmFwUmVjZWl2ZXJzKFxyXG4gICAgYXNzZW1ibHlLZXk6IEpXSy5LZXksXHJcbiAgICBldmVudDogc3RyaW5nLFxyXG4gICAgcmVjZWl2ZXJzOiBSZWNlaXZlcltdXHJcbiAgKSB7XHJcbiAgICBpZiAoIXJlY2VpdmVycyB8fCAhcmVjZWl2ZXJzLmxlbmd0aCkge1xyXG4gICAgICByZXR1cm4gW107XHJcbiAgICB9XHJcblxyXG4gICAgcmV0dXJuIGF3YWl0IFByb21pc2UuYWxsKFxyXG4gICAgICByZWNlaXZlcnMubWFwKGFzeW5jIChyZWNlaXZlcikgPT4ge1xyXG4gICAgICAgIGNvbnN0IHNoYXJlZEtleSA9IGF3YWl0IHRoaXMua2V5R3JhcGguZ2V0S2V5KHJlY2VpdmVyLmtleUlkKTtcclxuXHJcbiAgICAgICAgY29uc3QgcHJlcGFyZVJlY2VpdmVySXRlbSA9IGFzeW5jIChcclxuICAgICAgICAgIGl0ZW06IFJlY2VpdmVyQ2F0ZWdvcnkgfCBSZWNlaXZlclJlY29yZCxcclxuICAgICAgICAgIGl0ZW1LZXlJZDogc3RyaW5nXHJcbiAgICAgICAgKSA9PiB7XHJcbiAgICAgICAgICBjb25zdCBpdGVtS2V5ID0gYXdhaXQgdGhpcy5rZXlHcmFwaC5nZXRLZXkoaXRlbUtleUlkKTtcclxuICAgICAgICAgIGxldCB3cmFwcGVkSXRlbUtleSA9IGF3YWl0IHRoaXMua2V5R3JhcGguZW5jcnlwdFRvU3RyaW5nKFxyXG4gICAgICAgICAgICBzaGFyZWRLZXkuandrLFxyXG4gICAgICAgICAgICBpdGVtS2V5Lmp3ay50b0pTT04odHJ1ZSlcclxuICAgICAgICAgICk7XHJcblxyXG4gICAgICAgICAgaWYgKGFzc2VtYmx5S2V5KSB7XHJcbiAgICAgICAgICAgIHdyYXBwZWRJdGVtS2V5ID0gYXdhaXQgdGhpcy5rZXlHcmFwaC5lbmNyeXB0VG9TdHJpbmcoXHJcbiAgICAgICAgICAgICAgYXNzZW1ibHlLZXksXHJcbiAgICAgICAgICAgICAgd3JhcHBlZEl0ZW1LZXlcclxuICAgICAgICAgICAgKTtcclxuICAgICAgICAgIH1cclxuXHJcbiAgICAgICAgICByZXR1cm4ge1xyXG4gICAgICAgICAgICBhY2Nlc3NSb2xlOiBpdGVtLmFjY2Vzc0xldmVsLFxyXG4gICAgICAgICAgICBzaGFyZWRLZXlJZDogc2hhcmVkS2V5LmlkLFxyXG4gICAgICAgICAgICBzaGFyZWRDaXBoZXJEYXRhOiAnJyxcclxuICAgICAgICAgICAgd3JhcHBlZEl0ZW1LZXksXHJcbiAgICAgICAgICB9O1xyXG4gICAgICAgIH07XHJcblxyXG4gICAgICAgIC8vIEZvciBlYWNoIHJlY2VpdmVyLWRpcmVjdG9yeVxyXG4gICAgICAgIGNvbnN0IHJlY2VpdmVyRGlyZWN0b3JpZXMgPSBhd2FpdCBQcm9taXNlLmFsbChbXHJcbiAgICAgICAgICAuLi5yZWNlaXZlci5jYXRlZ29yaWVzLm1hcChhc3luYyAoeCkgPT4gKHtcclxuICAgICAgICAgICAgLi4uKGF3YWl0IHByZXBhcmVSZWNlaXZlckl0ZW0oeCwgeC5jYXRlZ29yeS5rZXlJZCkpLFxyXG4gICAgICAgICAgICByZWNlaXZlckRpcmVjdG9yeUlkOiB4LmlkLFxyXG4gICAgICAgICAgfSkpLFxyXG4gICAgICAgICAgLi4ucmVjZWl2ZXIucmVjb3Jkcy5tYXAoYXN5bmMgKHgpID0+ICh7XHJcbiAgICAgICAgICAgIC4uLihhd2FpdCBwcmVwYXJlUmVjZWl2ZXJJdGVtKHgsIHgucmVjb3JkLmtleUlkKSksXHJcbiAgICAgICAgICAgIHJlY2VpdmVyRGlyZWN0b3J5SWQ6IHguaWQsXHJcbiAgICAgICAgICB9KSksXHJcbiAgICAgICAgXSk7XHJcblxyXG4gICAgICAgIHJldHVybiB7XHJcbiAgICAgICAgICByZWNlaXZlcklkOiByZWNlaXZlci5pZCxcclxuICAgICAgICAgIHNoYXJlZEtleUlkOiByZWNlaXZlci5rZXlJZCxcclxuICAgICAgICAgIHJlY2VpdmVyRGlyZWN0b3JpZXMsXHJcbiAgICAgICAgICByZWNlaXZlckZpbGVzOiBbXSxcclxuICAgICAgICAgIHNoYXJlZENpcGhlckRhdGE6IGF3YWl0IHRoaXMua2V5R3JhcGguZW5jcnlwdFRvU3RyaW5nKHNoYXJlZEtleS5qd2ssIHtcclxuICAgICAgICAgICAgZXZlbnQsXHJcbiAgICAgICAgICAgIG1lc3NhZ2U6IHJlY2VpdmVyLm1lc3NhZ2UsXHJcbiAgICAgICAgICB9KSxcclxuICAgICAgICB9O1xyXG4gICAgICB9KVxyXG4gICAgKTtcclxuICB9XHJcblxyXG4gIHByaXZhdGUgYXN5bmMgbWFwQXBwcm92YWxHcm91cHMoXHJcbiAgICBhcHByb3ZhbEdyb3VwczogVXBkYXRlU2NlbmFyaW9BcHByb3ZhbEdyb3VwW10sXHJcbiAgICBxdW9ydW06IG51bWJlcixcclxuICAgIGFzc2VtYmx5S2V5OiBKV0suS2V5XHJcbiAgKSB7XHJcbiAgICBjb25zdCBzbGlwQXNzZW1ibHkgPSBhd2FpdCB0aGlzLmNyZWF0ZVNsaXBBc3NlbWJseShcclxuICAgICAgcXVvcnVtLFxyXG4gICAgICBhcHByb3ZhbEdyb3VwcyxcclxuICAgICAgKGFzc2VtYmx5S2V5LnRvSlNPTih0cnVlKSBhcyBhbnkpLmtcclxuICAgICk7XHJcbiAgICByZXR1cm4gYXdhaXQgUHJvbWlzZS5hbGwoXHJcbiAgICAgIGFwcHJvdmFsR3JvdXBzLm1hcCgoeCwgaW5kZXgpID0+XHJcbiAgICAgICAgdGhpcy5tYXBBcHByb3ZhbEdyb3VwKHgsIHNsaXBBc3NlbWJseS5zdWJBc3NlbWJsaWVzW2luZGV4XSwgYXNzZW1ibHlLZXkpXHJcbiAgICAgIClcclxuICAgICk7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIGFzeW5jIG1hcEFwcHJvdmFsR3JvdXAoXHJcbiAgICBhcHByb3ZhbEdyb3VwOiBVcGRhdGVTY2VuYXJpb0FwcHJvdmFsR3JvdXAsXHJcbiAgICBzdWJBc3NlbWJseTogc2xpcC5TdWJBc3NlbWJseSxcclxuICAgIGFzc2VtYmx5S2V5OiBKV0suS2V5XHJcbiAgKSB7XHJcbiAgICBjb25zdCBhcHByb3ZlcnMgPSBhd2FpdCB0aGlzLm1hcEFwcHJvdmVycyhcclxuICAgICAgYXBwcm92YWxHcm91cC5hcHByb3ZlcnMsXHJcbiAgICAgIGFwcHJvdmFsR3JvdXAucXVvcnVtLFxyXG4gICAgICBzdWJBc3NlbWJseSxcclxuICAgICAgYXNzZW1ibHlLZXlcclxuICAgICk7XHJcblxyXG4gICAgcmV0dXJuIHtcclxuICAgICAgc3ViQXNzZW1ibHlJZDogYXBwcm92YWxHcm91cC5zdWJBc3NlbWJseUlkLFxyXG4gICAgICBzaW5nbGVSZWplY3Q6IGFwcHJvdmFsR3JvdXAuc2luZ2xlUmVqZWN0LFxyXG4gICAgICBxdW9ydW06IGFwcHJvdmFsR3JvdXAucXVvcnVtLFxyXG4gICAgICBzdWJBc3NlbWJseUNpcGhlckRhdGE6IGF3YWl0IHRoaXMua2V5R3JhcGguZW5jcnlwdFRvU3RyaW5nKFxyXG4gICAgICAgIGFzc2VtYmx5S2V5LFxyXG4gICAgICAgIGFwcHJvdmFsR3JvdXAucGxhaW5TdWJBc3NlbWJseUNpcGhlckRhdGFcclxuICAgICAgKSxcclxuICAgICAgY3JlYXRlQXBwcm92ZXJzOiBhcHByb3ZlcnMuZmlsdGVyKCh4KSA9PiAheC5hcHByb3ZlcklkKSxcclxuICAgICAgdXBkYXRlQXBwcm92ZXJzOiBhcHByb3ZlcnMuZmlsdGVyKCh4KSA9PiB4LmFwcHJvdmVySWQpLFxyXG4gICAgICBkZWxldGVBcHByb3ZlcnM6IGFwcHJvdmFsR3JvdXAuZGVsZXRlZEFwcHJvdmVySWRzIHx8IFtdLFxyXG4gICAgfTtcclxuICB9XHJcblxyXG4gIHByaXZhdGUgYXN5bmMgbWFwQXBwcm92ZXJzKFxyXG4gICAgYXBwcm92ZXJzOiBVcGRhdGVTY2VuYXJpb0FwcHJvdmVyW10sXHJcbiAgICBxdW9ydW06IG51bWJlcixcclxuICAgIHN1YkFzc2VtYmx5OiBzbGlwLlN1YkFzc2VtYmx5LFxyXG4gICAgYXNzZW1ibHlLZXk6IEpXSy5LZXlcclxuICApIHtcclxuICAgIGNvbnN0IHsgazogcmF3QXNzZW1ibHlLZXksIC4uLmFzc2VtYmx5S2V5UGFyYW1zIH0gPSBhc3NlbWJseUtleS50b0pTT04oXHJcbiAgICAgIHRydWVcclxuICAgICkgYXMgYW55O1xyXG4gICAgbGV0IHNoYXJlSWR4ID0gMDtcclxuXHJcbiAgICBjb25zdCBuZXh0UGFydGlhbEFzc2VtYmx5S2V5ID0gYXN5bmMgKHNoYXJlZEtleUp3azogSldLLktleSkgPT4ge1xyXG4gICAgICBjb25zdCBzaGFyZSA9IHN1YkFzc2VtYmx5LnNoYXJlc1tzaGFyZUlkeF07XHJcbiAgICAgIC8vIElmIHF1b3J1bSBpcyAxLCB0aGVuIHVzaW5nIHRoZSBzYW1lIHNoYXJlIGZvciBldmVyeSBtZW1iZXIuXHJcbiAgICAgIGlmIChxdW9ydW0gIT09IDEpIHtcclxuICAgICAgICArK3NoYXJlSWR4O1xyXG4gICAgICB9XHJcbiAgICAgIGNvbnN0IHBhcnRpYWxBc3NlbWJseUtleTogUGFydGlhbEFzc2VtYmx5S2V5ID0ge1xyXG4gICAgICAgIHNsaXAzOToge1xyXG4gICAgICAgICAgc2hhcmUsXHJcbiAgICAgICAgICBzdWJBc3NlbWJseToge1xyXG4gICAgICAgICAgICBxdW9ydW0sXHJcbiAgICAgICAgICAgIHNpemU6IGFwcHJvdmVycy5sZW5ndGgsXHJcbiAgICAgICAgICB9LFxyXG4gICAgICAgIH0sXHJcbiAgICAgICAgYXNzZW1ibHlLZXlQYXJhbXMsXHJcbiAgICAgIH07XHJcbiAgICAgIHJldHVybiB0aGlzLmtleUdyYXBoLmVuY3J5cHRUb1N0cmluZyhzaGFyZWRLZXlKd2ssIHBhcnRpYWxBc3NlbWJseUtleSk7XHJcbiAgICB9O1xyXG5cclxuICAgIHJldHVybiBhd2FpdCBQcm9taXNlLmFsbChcclxuICAgICAgYXBwcm92ZXJzLm1hcChhc3luYyAoeCkgPT4ge1xyXG4gICAgICAgIGlmICh4LmFwcHJvdmVySWQpIHtcclxuICAgICAgICAgIGNvbnN0IHNoYXJlZEtleSA9IGF3YWl0IHRoaXMua2V5R3JhcGguZ2V0S2V5KHgua2V5SWQpO1xyXG4gICAgICAgICAgY29uc3Qgc2hhcmVkQ2lwaGVyRGF0YSA9IGF3YWl0IHRoaXMua2V5R3JhcGguZW5jcnlwdFRvU3RyaW5nKFxyXG4gICAgICAgICAgICB4LmtleUlkLFxyXG4gICAgICAgICAgICB4LnBsYWluU2hhcmVkQ2lwaGVyRGF0YVxyXG4gICAgICAgICAgKTtcclxuICAgICAgICAgIGNvbnN0IHNoYXJlZENpcGhlckFwcHJvdmFsRGF0YSA9IGF3YWl0IHRoaXMua2V5R3JhcGguZW5jcnlwdFRvU3RyaW5nKFxyXG4gICAgICAgICAgICB4LmtleUlkLFxyXG4gICAgICAgICAgICB4LmFwcHJvdmFsRGF0YVxyXG4gICAgICAgICAgKTtcclxuXHJcbiAgICAgICAgICByZXR1cm4ge1xyXG4gICAgICAgICAgICBhcHByb3ZlcklkOiB4LmFwcHJvdmVySWQsXHJcbiAgICAgICAgICAgIHNoYXJlZEtleUlkOiB4LmtleUlkLFxyXG4gICAgICAgICAgICBzaGFyZWRDaXBoZXJEYXRhOiBzaGFyZWRDaXBoZXJEYXRhIHx8ICcnLFxyXG4gICAgICAgICAgICBzaGFyZWRDaXBoZXJBcHByb3ZhbERhdGE6IHNoYXJlZENpcGhlckFwcHJvdmFsRGF0YSB8fCAnJyxcclxuICAgICAgICAgICAgc2hhcmVkQ2lwaGVyUGFydGlhbEFzc2VtYmx5S2V5OiBhd2FpdCBuZXh0UGFydGlhbEFzc2VtYmx5S2V5KFxyXG4gICAgICAgICAgICAgIHNoYXJlZEtleS5qd2tcclxuICAgICAgICAgICAgKSxcclxuICAgICAgICAgIH07XHJcbiAgICAgICAgfSBlbHNlIHtcclxuICAgICAgICAgIGNvbnN0IHdyYXBwZWRDb250ZW50ID0gYXdhaXQgdGhpcy5rZXlNZXRhU2VydmljZS53cmFwQ29udGVudFdpdGhLZXkoXHJcbiAgICAgICAgICAgIHgucGxhaW5TaGFyZWRDaXBoZXJEYXRhLFxyXG4gICAgICAgICAgICB4LnRydXN0ZWRQYXJ0eVNoYXJlZEtleUlkXHJcbiAgICAgICAgICApO1xyXG5cclxuICAgICAgICAgIHJldHVybiB7XHJcbiAgICAgICAgICAgIHRwSWQ6IHgudHJ1c3RlZFBhcnR5SWQsXHJcbiAgICAgICAgICAgIHRwU2hhcmVkS2V5SWQ6IHgudHJ1c3RlZFBhcnR5U2hhcmVkS2V5SWQsXHJcbiAgICAgICAgICAgIHRwU2hhcmVkS2V5V3JhcHBlZFNoYXJlZEtleTogd3JhcHBlZENvbnRlbnQucm9vdEtleS53cmFwcGVkS2V5LFxyXG4gICAgICAgICAgICBzaGFyZWRDaXBoZXJEYXRhOiB3cmFwcGVkQ29udGVudC5jaXBoZXJNZXRhLFxyXG4gICAgICAgICAgICBzaGFyZWRDaXBoZXJBcHByb3ZhbERhdGE6ICcnLFxyXG4gICAgICAgICAgICBzaGFyZWRDaXBoZXJQYXJ0aWFsQXNzZW1ibHlLZXk6IGF3YWl0IG5leHRQYXJ0aWFsQXNzZW1ibHlLZXkoXHJcbiAgICAgICAgICAgICAgd3JhcHBlZENvbnRlbnQua2V5XHJcbiAgICAgICAgICAgICksXHJcbiAgICAgICAgICB9O1xyXG4gICAgICAgIH1cclxuICAgICAgfSlcclxuICAgICk7XHJcbiAgfVxyXG5cclxuICAvLyBTcGxpdCBhc3NlbWJseSBrZXkgYmV0d2VlbiBhbGwgZXhpc3RpbmcgYXBwcm92ZXJzLlxyXG4gIHByaXZhdGUgYXN5bmMgY3JlYXRlU2xpcEFzc2VtYmx5KFxyXG4gICAgcXVvcnVtOiBudW1iZXIsXHJcbiAgICBhcHByb3ZhbEdyb3VwczogVXBkYXRlU2NlbmFyaW9BcHByb3ZhbEdyb3VwW10sXHJcbiAgICByYXdBc3NlbWJseUtleTogc3RyaW5nXHJcbiAgKTogUHJvbWlzZTxzbGlwLkFzc2VtYmx5PiB7XHJcbiAgICBjb25zdCBzbGlwQXNzZW1ibHkgPSBuZXcgc2xpcC5Bc3NlbWJseShxdW9ydW0pO1xyXG5cclxuICAgIGFwcHJvdmFsR3JvdXBzLmZvckVhY2goKHgsIGluZGV4KSA9PiB7XHJcbiAgICAgIGxldCBhcHByb3ZlckNvdW50ID0geC5hcHByb3ZlcnMubGVuZ3RoO1xyXG5cclxuICAgICAgLy8gc2xpcDM5IHJlc3RyaWN0cyBxdW9ydW0gPT0gMSB0byBoYXZlIG9ubHkgMSBtZW1iZXIuIFNvIHdlIGp1c3Qgc2hhcmUgdGhlIHNhbWVcclxuICAgICAgLy8gcGFydGlhbCBrZXkgZm9yIGFsbCBzdWIgYXNzZW1ibHkgbWVtYmVycy5cclxuICAgICAgaWYgKHgucXVvcnVtID09PSAxKSB7XHJcbiAgICAgICAgYXBwcm92ZXJDb3VudCA9IDE7XHJcbiAgICAgIH1cclxuICAgICAgc2xpcEFzc2VtYmx5LmFkZFN1YkFzc2VtYmx5KFxyXG4gICAgICAgIG5ldyBzbGlwLlN1YkFzc2VtYmx5KGluZGV4LCB4LnF1b3J1bSwgYXBwcm92ZXJDb3VudClcclxuICAgICAgKTtcclxuICAgIH0pO1xyXG4gICAgLy8gSXMgdGhlcmUgZW5vdWdoIHN1YiBhc3NlbWJsaWVzIHRvIG1lZXQgcXVvcnVtXHJcbiAgICBpZiAoc2xpcEFzc2VtYmx5LnN1YkFzc2VtYmxpZXMubGVuZ3RoIDwgcXVvcnVtKSB7XHJcbiAgICAgIHJldHVybiBudWxsO1xyXG4gICAgfVxyXG4gICAgYXdhaXQgdGhpcy5zbGlwMzlTZXJ2aWNlLmdlbmVyYXRlU2hhcmVzKFxyXG4gICAgICByYXdBc3NlbWJseUtleSxcclxuICAgICAgU2NlbmFyaW9BcHByb3ZlclNlcnZpY2UuU0xJUDM5X1BBU1NQSFJBU0UsXHJcbiAgICAgIHNsaXBBc3NlbWJseVxyXG4gICAgKTtcclxuICAgIHJldHVybiBzbGlwQXNzZW1ibHk7XHJcbiAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import gql from 'graphql-tag';
|
|
2
|
+
import { KeyGraphField } from '../../_common/queries.gql';
|
|
3
|
+
import { TrustedPartyProperties } from '../../trusted-parties/trusted-party.gql';
|
|
4
|
+
export const ClaimantFields = `
|
|
5
|
+
id
|
|
6
|
+
tp {
|
|
7
|
+
${TrustedPartyProperties}
|
|
8
|
+
}
|
|
9
|
+
sharedKey {
|
|
10
|
+
id
|
|
11
|
+
}
|
|
12
|
+
sharedCipherData
|
|
13
|
+
`;
|
|
14
|
+
export const GetScenarioClaimantQuery = gql `
|
|
15
|
+
query GetScenarioClaimantQuery(
|
|
16
|
+
$id: LrRelayIdInput!
|
|
17
|
+
) {
|
|
18
|
+
scenarioClaimant(id: $id) {
|
|
19
|
+
${ClaimantFields}
|
|
20
|
+
}
|
|
21
|
+
${KeyGraphField}
|
|
22
|
+
}`;
|
|
23
|
+
export const AddScenarioClaimantMutation = gql `
|
|
24
|
+
mutation AddScenarioClaimantMutation($input: AddScenarioClaimantInput!) {
|
|
25
|
+
addScenarioClaimant(input: $input) {
|
|
26
|
+
claimant {
|
|
27
|
+
id
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
`;
|
|
32
|
+
export const UpdateScenarioClaimantMutation = gql `
|
|
33
|
+
mutation UpdateScenarioClaimantMutation(
|
|
34
|
+
$input: UpdateScenarioClaimantInput!
|
|
35
|
+
) {
|
|
36
|
+
updateScenarioClaimant(input: $input) {
|
|
37
|
+
claimant {
|
|
38
|
+
id
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
`;
|
|
43
|
+
export const DeleteScenarioClaimantMutation = gql `
|
|
44
|
+
mutation DeleteScenarioClaimantMutation(
|
|
45
|
+
$input: DeleteScenarioClaimantInput!
|
|
46
|
+
) {
|
|
47
|
+
deleteScenarioClaimant(input: $input) {
|
|
48
|
+
id
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
`;
|
|
52
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NlbmFyaW8tY2xhaW1hbnQuZ3FsLmpzIiwic291cmNlUm9vdCI6IkM6L1Byb2plY3RzL3Rlc3QvcHJvamVjdHMvY29yZS9zcmMvIiwic291cmNlcyI6WyJsaWIvc2NlbmFyaW8vY2xhaW1hbnRzL3NjZW5hcmlvLWNsYWltYW50LmdxbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEdBQUcsTUFBTSxhQUFhLENBQUM7QUFDOUIsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzFELE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHlDQUF5QyxDQUFDO0FBRWpGLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRzs7O0lBRzFCLHNCQUFzQjs7Ozs7O0NBTXpCLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSx3QkFBd0IsR0FBRyxHQUFHLENBQUE7Ozs7O01BS3JDLGNBQWM7O0lBRWhCLGFBQWE7RUFDZixDQUFDO0FBRUgsTUFBTSxDQUFDLE1BQU0sMkJBQTJCLEdBQUcsR0FBRyxDQUFBOzs7Ozs7OztDQVE3QyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sOEJBQThCLEdBQUcsR0FBRyxDQUFBOzs7Ozs7Ozs7O0NBVWhELENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSw4QkFBOEIsR0FBRyxHQUFHLENBQUE7Ozs7Ozs7O0NBUWhELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgZ3FsIGZyb20gJ2dyYXBocWwtdGFnJztcclxuaW1wb3J0IHsgS2V5R3JhcGhGaWVsZCB9IGZyb20gJy4uLy4uL19jb21tb24vcXVlcmllcy5ncWwnO1xyXG5pbXBvcnQgeyBUcnVzdGVkUGFydHlQcm9wZXJ0aWVzIH0gZnJvbSAnLi4vLi4vdHJ1c3RlZC1wYXJ0aWVzL3RydXN0ZWQtcGFydHkuZ3FsJztcclxuXHJcbmV4cG9ydCBjb25zdCBDbGFpbWFudEZpZWxkcyA9IGBcclxuaWRcclxudHAge1xyXG4gICR7VHJ1c3RlZFBhcnR5UHJvcGVydGllc31cclxufVxyXG5zaGFyZWRLZXkge1xyXG4gIGlkXHJcbn1cclxuc2hhcmVkQ2lwaGVyRGF0YVxyXG5gO1xyXG5cclxuZXhwb3J0IGNvbnN0IEdldFNjZW5hcmlvQ2xhaW1hbnRRdWVyeSA9IGdxbGBcclxucXVlcnkgR2V0U2NlbmFyaW9DbGFpbWFudFF1ZXJ5KFxyXG4gICRpZDogTHJSZWxheUlkSW5wdXQhXHJcbikge1xyXG4gIHNjZW5hcmlvQ2xhaW1hbnQoaWQ6ICRpZCkge1xyXG4gICAgJHtDbGFpbWFudEZpZWxkc31cclxuICB9XHJcbiAgJHtLZXlHcmFwaEZpZWxkfVxyXG59YDtcclxuXHJcbmV4cG9ydCBjb25zdCBBZGRTY2VuYXJpb0NsYWltYW50TXV0YXRpb24gPSBncWxgXHJcbiAgbXV0YXRpb24gQWRkU2NlbmFyaW9DbGFpbWFudE11dGF0aW9uKCRpbnB1dDogQWRkU2NlbmFyaW9DbGFpbWFudElucHV0ISkge1xyXG4gICAgYWRkU2NlbmFyaW9DbGFpbWFudChpbnB1dDogJGlucHV0KSB7XHJcbiAgICAgIGNsYWltYW50IHtcclxuICAgICAgICBpZFxyXG4gICAgICB9XHJcbiAgICB9XHJcbiAgfVxyXG5gO1xyXG5cclxuZXhwb3J0IGNvbnN0IFVwZGF0ZVNjZW5hcmlvQ2xhaW1hbnRNdXRhdGlvbiA9IGdxbGBcclxuICBtdXRhdGlvbiBVcGRhdGVTY2VuYXJpb0NsYWltYW50TXV0YXRpb24oXHJcbiAgICAkaW5wdXQ6IFVwZGF0ZVNjZW5hcmlvQ2xhaW1hbnRJbnB1dCFcclxuICApIHtcclxuICAgIHVwZGF0ZVNjZW5hcmlvQ2xhaW1hbnQoaW5wdXQ6ICRpbnB1dCkge1xyXG4gICAgICBjbGFpbWFudCB7XHJcbiAgICAgICAgaWRcclxuICAgICAgfVxyXG4gICAgfVxyXG4gIH1cclxuYDtcclxuXHJcbmV4cG9ydCBjb25zdCBEZWxldGVTY2VuYXJpb0NsYWltYW50TXV0YXRpb24gPSBncWxgXHJcbiAgbXV0YXRpb24gRGVsZXRlU2NlbmFyaW9DbGFpbWFudE11dGF0aW9uKFxyXG4gICAgJGlucHV0OiBEZWxldGVTY2VuYXJpb0NsYWltYW50SW5wdXQhXHJcbiAgKSB7XHJcbiAgICBkZWxldGVTY2VuYXJpb0NsYWltYW50KGlucHV0OiAkaW5wdXQpIHtcclxuICAgICAgaWRcclxuICAgIH1cclxuICB9XHJcbmA7XHJcbiJdfQ==
|
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
2
|
+
import { Injectable } from '@angular/core';
|
|
3
|
+
import { LrApolloService } from '../../api/lr-apollo.service';
|
|
4
|
+
import { KeyGraphService } from '../../cryptography/key-graph.service';
|
|
5
|
+
import { KeyMetaService } from '../../cryptography/key-meta.service';
|
|
6
|
+
import { TrustedPartyService } from '../../trusted-parties/trusted-party.service';
|
|
7
|
+
import { DeleteScenarioClaimantMutation, UpdateScenarioClaimantMutation, GetScenarioClaimantQuery, AddScenarioClaimantMutation, } from './scenario-claimant.gql';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "../../api/lr-apollo.service";
|
|
10
|
+
import * as i2 from "../../cryptography/key-meta.service";
|
|
11
|
+
import * as i3 from "../../cryptography/key-graph.service";
|
|
12
|
+
import * as i4 from "../../trusted-parties/trusted-party.service";
|
|
13
|
+
export class ScenarioClaimantService {
|
|
14
|
+
constructor(lrApollo, keyMetaService, keyGraph, tpService) {
|
|
15
|
+
this.lrApollo = lrApollo;
|
|
16
|
+
this.keyMetaService = keyMetaService;
|
|
17
|
+
this.keyGraph = keyGraph;
|
|
18
|
+
this.tpService = tpService;
|
|
19
|
+
}
|
|
20
|
+
getClaimant(claimantId) {
|
|
21
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
22
|
+
const { scenarioClaimant } = yield this.lrApollo.query({
|
|
23
|
+
query: GetScenarioClaimantQuery,
|
|
24
|
+
variables: {
|
|
25
|
+
id: claimantId,
|
|
26
|
+
},
|
|
27
|
+
});
|
|
28
|
+
return this.mapClaimant(scenarioClaimant);
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
mapClaimant(claimant) {
|
|
32
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
33
|
+
const { message } = yield this.keyGraph.decryptFromString(claimant.sharedKey.id, claimant.sharedCipherData);
|
|
34
|
+
return {
|
|
35
|
+
id: claimant.id,
|
|
36
|
+
keyId: claimant.sharedKey.id,
|
|
37
|
+
trustedParty: yield this.tpService.mapTrustedParty(claimant.tp),
|
|
38
|
+
message,
|
|
39
|
+
};
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
addClaimant(claimant) {
|
|
43
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
44
|
+
const wrappedContent = yield this.keyMetaService.wrapContentWithKey(claimant.plainSharedCipherData, claimant.trustedPartySharedKeyId);
|
|
45
|
+
const { addScenarioClaimant } = yield this.lrApollo.mutate({
|
|
46
|
+
mutation: AddScenarioClaimantMutation,
|
|
47
|
+
variables: {
|
|
48
|
+
input: {
|
|
49
|
+
scenarioId: claimant.scenarioId,
|
|
50
|
+
tpId: claimant.trustedPartyId,
|
|
51
|
+
tpSharedKeyId: claimant.trustedPartySharedKeyId,
|
|
52
|
+
tpSharedKeyWrappedSharedKey: wrappedContent.rootKey.wrappedKey,
|
|
53
|
+
sharedCipherData: wrappedContent.cipherMeta,
|
|
54
|
+
},
|
|
55
|
+
},
|
|
56
|
+
});
|
|
57
|
+
return addScenarioClaimant.claimant.id;
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
updateClaimant(claimant) {
|
|
61
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
62
|
+
const sharedCipherData = yield this.keyGraph.encryptToString(claimant.keyId, claimant.plainSharedCipherData);
|
|
63
|
+
const res = yield this.lrApollo.mutate({
|
|
64
|
+
mutation: UpdateScenarioClaimantMutation,
|
|
65
|
+
variables: {
|
|
66
|
+
input: {
|
|
67
|
+
claimantId: claimant.id,
|
|
68
|
+
sharedKeyId: claimant.keyId,
|
|
69
|
+
sharedCipherData,
|
|
70
|
+
},
|
|
71
|
+
},
|
|
72
|
+
});
|
|
73
|
+
return res.updateScenarioClaimant.claimant.id;
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
deleteClaimant(claimantId) {
|
|
77
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
78
|
+
yield this.lrApollo.mutate({
|
|
79
|
+
mutation: DeleteScenarioClaimantMutation,
|
|
80
|
+
variables: { input: { claimantId } },
|
|
81
|
+
});
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
ScenarioClaimantService.ɵprov = i0.ɵɵdefineInjectable({ factory: function ScenarioClaimantService_Factory() { return new ScenarioClaimantService(i0.ɵɵinject(i1.LrApolloService), i0.ɵɵinject(i2.KeyMetaService), i0.ɵɵinject(i3.KeyGraphService), i0.ɵɵinject(i4.TrustedPartyService)); }, token: ScenarioClaimantService, providedIn: "root" });
|
|
86
|
+
ScenarioClaimantService.decorators = [
|
|
87
|
+
{ type: Injectable, args: [{
|
|
88
|
+
providedIn: 'root',
|
|
89
|
+
},] }
|
|
90
|
+
];
|
|
91
|
+
ScenarioClaimantService.ctorParameters = () => [
|
|
92
|
+
{ type: LrApolloService },
|
|
93
|
+
{ type: KeyMetaService },
|
|
94
|
+
{ type: KeyGraphService },
|
|
95
|
+
{ type: TrustedPartyService }
|
|
96
|
+
];
|
|
97
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NlbmFyaW8tY2xhaW1hbnQuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiJDOi9Qcm9qZWN0cy90ZXN0L3Byb2plY3RzL2NvcmUvc3JjLyIsInNvdXJjZXMiOlsibGliL3NjZW5hcmlvL2NsYWltYW50cy9zY2VuYXJpby1jbGFpbWFudC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUM5RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDdkUsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQ3JFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLDZDQUE2QyxDQUFDO0FBQ2xGLE9BQU8sRUFDTCw4QkFBOEIsRUFDOUIsOEJBQThCLEVBQzlCLHdCQUF3QixFQUN4QiwyQkFBMkIsR0FDNUIsTUFBTSx5QkFBeUIsQ0FBQzs7Ozs7O0FBVWpDLE1BQU0sT0FBTyx1QkFBdUI7SUFDbEMsWUFDVSxRQUF5QixFQUN6QixjQUE4QixFQUM5QixRQUF5QixFQUN6QixTQUE4QjtRQUg5QixhQUFRLEdBQVIsUUFBUSxDQUFpQjtRQUN6QixtQkFBYyxHQUFkLGNBQWMsQ0FBZ0I7UUFDOUIsYUFBUSxHQUFSLFFBQVEsQ0FBaUI7UUFDekIsY0FBUyxHQUFULFNBQVMsQ0FBcUI7SUFDckMsQ0FBQztJQUVTLFdBQVcsQ0FBQyxVQUFrQjs7WUFDekMsTUFBTSxFQUFFLGdCQUFnQixFQUFFLEdBQUcsTUFBTSxJQUFJLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBTTtnQkFDMUQsS0FBSyxFQUFFLHdCQUF3QjtnQkFDL0IsU0FBUyxFQUFFO29CQUNULEVBQUUsRUFBRSxVQUFVO2lCQUNmO2FBQ0YsQ0FBQyxDQUFDO1lBQ0gsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDLGdCQUFnQixDQUFDLENBQUM7UUFDNUMsQ0FBQztLQUFBO0lBRVksV0FBVyxDQUFDLFFBQWE7O1lBQ3BDLE1BQU0sRUFBRSxPQUFPLEVBQUUsR0FBRyxNQUFNLElBQUksQ0FBQyxRQUFRLENBQUMsaUJBQWlCLENBRXRELFFBQVEsQ0FBQyxTQUFTLENBQUMsRUFBRSxFQUFFLFFBQVEsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1lBRXJELE9BQU87Z0JBQ0wsRUFBRSxFQUFFLFFBQVEsQ0FBQyxFQUFFO2dCQUNmLEtBQUssRUFBRSxRQUFRLENBQUMsU0FBUyxDQUFDLEVBQUU7Z0JBQzVCLFlBQVksRUFBRSxNQUFNLElBQUksQ0FBQyxTQUFTLENBQUMsZUFBZSxDQUFDLFFBQVEsQ0FBQyxFQUFFLENBQUM7Z0JBQy9ELE9BQU87YUFDUixDQUFDO1FBQ0osQ0FBQztLQUFBO0lBRVksV0FBVyxDQUFDLFFBQTZCOztZQUNwRCxNQUFNLGNBQWMsR0FBRyxNQUFNLElBQUksQ0FBQyxjQUFjLENBQUMsa0JBQWtCLENBQ2pFLFFBQVEsQ0FBQyxxQkFBcUIsRUFDOUIsUUFBUSxDQUFDLHVCQUF1QixDQUNqQyxDQUFDO1lBRUYsTUFBTSxFQUFFLG1CQUFtQixFQUFFLEdBQUcsTUFBTSxJQUFJLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBTTtnQkFDOUQsUUFBUSxFQUFFLDJCQUEyQjtnQkFDckMsU0FBUyxFQUFFO29CQUNULEtBQUssRUFBRTt3QkFDTCxVQUFVLEVBQUUsUUFBUSxDQUFDLFVBQVU7d0JBQy9CLElBQUksRUFBRSxRQUFRLENBQUMsY0FBYzt3QkFDN0IsYUFBYSxFQUFFLFFBQVEsQ0FBQyx1QkFBdUI7d0JBQy9DLDJCQUEyQixFQUFFLGNBQWMsQ0FBQyxPQUFPLENBQUMsVUFBVTt3QkFDOUQsZ0JBQWdCLEVBQUUsY0FBYyxDQUFDLFVBQVU7cUJBQzVDO2lCQUNGO2FBQ0YsQ0FBQyxDQUFDO1lBQ0gsT0FBTyxtQkFBbUIsQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDO1FBQ3pDLENBQUM7S0FBQTtJQUVZLGNBQWMsQ0FDekIsUUFBZ0M7O1lBRWhDLE1BQU0sZ0JBQWdCLEdBQUcsTUFBTSxJQUFJLENBQUMsUUFBUSxDQUFDLGVBQWUsQ0FDMUQsUUFBUSxDQUFDLEtBQUssRUFDZCxRQUFRLENBQUMscUJBQXFCLENBQy9CLENBQUM7WUFFRixNQUFNLEdBQUcsR0FBRyxNQUFNLElBQUksQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFNO2dCQUMxQyxRQUFRLEVBQUUsOEJBQThCO2dCQUN4QyxTQUFTLEVBQUU7b0JBQ1QsS0FBSyxFQUFFO3dCQUNMLFVBQVUsRUFBRSxRQUFRLENBQUMsRUFBRTt3QkFDdkIsV0FBVyxFQUFFLFFBQVEsQ0FBQyxLQUFLO3dCQUMzQixnQkFBZ0I7cUJBQ2pCO2lCQUNGO2FBQ0YsQ0FBQyxDQUFDO1lBQ0gsT0FBTyxHQUFHLENBQUMsc0JBQXNCLENBQUMsUUFBUSxDQUFDLEVBQUUsQ0FBQztRQUNoRCxDQUFDO0tBQUE7SUFFWSxjQUFjLENBQUMsVUFBa0I7O1lBQzVDLE1BQU0sSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQU07Z0JBQzlCLFFBQVEsRUFBRSw4QkFBOEI7Z0JBQ3hDLFNBQVMsRUFBRSxFQUFFLEtBQUssRUFBRSxFQUFFLFVBQVUsRUFBRSxFQUFFO2FBQ3JDLENBQUMsQ0FBQztRQUNMLENBQUM7S0FBQTs7OztZQWpGRixVQUFVLFNBQUM7Z0JBQ1YsVUFBVSxFQUFFLE1BQU07YUFDbkI7OztZQWxCUSxlQUFlO1lBRWYsY0FBYztZQURkLGVBQWU7WUFFZixtQkFBbUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IExyQXBvbGxvU2VydmljZSB9IGZyb20gJy4uLy4uL2FwaS9sci1hcG9sbG8uc2VydmljZSc7XHJcbmltcG9ydCB7IEtleUdyYXBoU2VydmljZSB9IGZyb20gJy4uLy4uL2NyeXB0b2dyYXBoeS9rZXktZ3JhcGguc2VydmljZSc7XHJcbmltcG9ydCB7IEtleU1ldGFTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vY3J5cHRvZ3JhcGh5L2tleS1tZXRhLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBUcnVzdGVkUGFydHlTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vdHJ1c3RlZC1wYXJ0aWVzL3RydXN0ZWQtcGFydHkuc2VydmljZSc7XHJcbmltcG9ydCB7XHJcbiAgRGVsZXRlU2NlbmFyaW9DbGFpbWFudE11dGF0aW9uLFxyXG4gIFVwZGF0ZVNjZW5hcmlvQ2xhaW1hbnRNdXRhdGlvbixcclxuICBHZXRTY2VuYXJpb0NsYWltYW50UXVlcnksXHJcbiAgQWRkU2NlbmFyaW9DbGFpbWFudE11dGF0aW9uLFxyXG59IGZyb20gJy4vc2NlbmFyaW8tY2xhaW1hbnQuZ3FsJztcclxuaW1wb3J0IHtcclxuICBDbGFpbWFudCxcclxuICBBZGRTY2VuYXJpb0NsYWltYW50LFxyXG4gIFVwZGF0ZVNjZW5hcmlvQ2xhaW1hbnQsXHJcbn0gZnJvbSAnLi9zY2VuYXJpby1jbGFpbWFudC50eXBlcyc7XHJcblxyXG5ASW5qZWN0YWJsZSh7XHJcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgU2NlbmFyaW9DbGFpbWFudFNlcnZpY2Uge1xyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgcHJpdmF0ZSBsckFwb2xsbzogTHJBcG9sbG9TZXJ2aWNlLFxyXG4gICAgcHJpdmF0ZSBrZXlNZXRhU2VydmljZTogS2V5TWV0YVNlcnZpY2UsXHJcbiAgICBwcml2YXRlIGtleUdyYXBoOiBLZXlHcmFwaFNlcnZpY2UsXHJcbiAgICBwcml2YXRlIHRwU2VydmljZTogVHJ1c3RlZFBhcnR5U2VydmljZVxyXG4gICkge31cclxuXHJcbiAgcHVibGljIGFzeW5jIGdldENsYWltYW50KGNsYWltYW50SWQ6IHN0cmluZyk6IFByb21pc2U8Q2xhaW1hbnQ+IHtcclxuICAgIGNvbnN0IHsgc2NlbmFyaW9DbGFpbWFudCB9ID0gYXdhaXQgdGhpcy5sckFwb2xsby5xdWVyeTxhbnk+KHtcclxuICAgICAgcXVlcnk6IEdldFNjZW5hcmlvQ2xhaW1hbnRRdWVyeSxcclxuICAgICAgdmFyaWFibGVzOiB7XHJcbiAgICAgICAgaWQ6IGNsYWltYW50SWQsXHJcbiAgICAgIH0sXHJcbiAgICB9KTtcclxuICAgIHJldHVybiB0aGlzLm1hcENsYWltYW50KHNjZW5hcmlvQ2xhaW1hbnQpO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGFzeW5jIG1hcENsYWltYW50KGNsYWltYW50OiBhbnkpOiBQcm9taXNlPENsYWltYW50PiB7XHJcbiAgICBjb25zdCB7IG1lc3NhZ2UgfSA9IGF3YWl0IHRoaXMua2V5R3JhcGguZGVjcnlwdEZyb21TdHJpbmc8e1xyXG4gICAgICBtZXNzYWdlOiBzdHJpbmc7XHJcbiAgICB9PihjbGFpbWFudC5zaGFyZWRLZXkuaWQsIGNsYWltYW50LnNoYXJlZENpcGhlckRhdGEpO1xyXG5cclxuICAgIHJldHVybiB7XHJcbiAgICAgIGlkOiBjbGFpbWFudC5pZCxcclxuICAgICAga2V5SWQ6IGNsYWltYW50LnNoYXJlZEtleS5pZCxcclxuICAgICAgdHJ1c3RlZFBhcnR5OiBhd2FpdCB0aGlzLnRwU2VydmljZS5tYXBUcnVzdGVkUGFydHkoY2xhaW1hbnQudHApLFxyXG4gICAgICBtZXNzYWdlLFxyXG4gICAgfTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBhc3luYyBhZGRDbGFpbWFudChjbGFpbWFudDogQWRkU2NlbmFyaW9DbGFpbWFudCk6IFByb21pc2U8c3RyaW5nPiB7XHJcbiAgICBjb25zdCB3cmFwcGVkQ29udGVudCA9IGF3YWl0IHRoaXMua2V5TWV0YVNlcnZpY2Uud3JhcENvbnRlbnRXaXRoS2V5KFxyXG4gICAgICBjbGFpbWFudC5wbGFpblNoYXJlZENpcGhlckRhdGEsXHJcbiAgICAgIGNsYWltYW50LnRydXN0ZWRQYXJ0eVNoYXJlZEtleUlkXHJcbiAgICApO1xyXG5cclxuICAgIGNvbnN0IHsgYWRkU2NlbmFyaW9DbGFpbWFudCB9ID0gYXdhaXQgdGhpcy5sckFwb2xsby5tdXRhdGU8YW55Pih7XHJcbiAgICAgIG11dGF0aW9uOiBBZGRTY2VuYXJpb0NsYWltYW50TXV0YXRpb24sXHJcbiAgICAgIHZhcmlhYmxlczoge1xyXG4gICAgICAgIGlucHV0OiB7XHJcbiAgICAgICAgICBzY2VuYXJpb0lkOiBjbGFpbWFudC5zY2VuYXJpb0lkLFxyXG4gICAgICAgICAgdHBJZDogY2xhaW1hbnQudHJ1c3RlZFBhcnR5SWQsXHJcbiAgICAgICAgICB0cFNoYXJlZEtleUlkOiBjbGFpbWFudC50cnVzdGVkUGFydHlTaGFyZWRLZXlJZCxcclxuICAgICAgICAgIHRwU2hhcmVkS2V5V3JhcHBlZFNoYXJlZEtleTogd3JhcHBlZENvbnRlbnQucm9vdEtleS53cmFwcGVkS2V5LFxyXG4gICAgICAgICAgc2hhcmVkQ2lwaGVyRGF0YTogd3JhcHBlZENvbnRlbnQuY2lwaGVyTWV0YSxcclxuICAgICAgICB9LFxyXG4gICAgICB9LFxyXG4gICAgfSk7XHJcbiAgICByZXR1cm4gYWRkU2NlbmFyaW9DbGFpbWFudC5jbGFpbWFudC5pZDtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBhc3luYyB1cGRhdGVDbGFpbWFudChcclxuICAgIGNsYWltYW50OiBVcGRhdGVTY2VuYXJpb0NsYWltYW50XHJcbiAgKTogUHJvbWlzZTxzdHJpbmc+IHtcclxuICAgIGNvbnN0IHNoYXJlZENpcGhlckRhdGEgPSBhd2FpdCB0aGlzLmtleUdyYXBoLmVuY3J5cHRUb1N0cmluZyhcclxuICAgICAgY2xhaW1hbnQua2V5SWQsXHJcbiAgICAgIGNsYWltYW50LnBsYWluU2hhcmVkQ2lwaGVyRGF0YVxyXG4gICAgKTtcclxuXHJcbiAgICBjb25zdCByZXMgPSBhd2FpdCB0aGlzLmxyQXBvbGxvLm11dGF0ZTxhbnk+KHtcclxuICAgICAgbXV0YXRpb246IFVwZGF0ZVNjZW5hcmlvQ2xhaW1hbnRNdXRhdGlvbixcclxuICAgICAgdmFyaWFibGVzOiB7XHJcbiAgICAgICAgaW5wdXQ6IHtcclxuICAgICAgICAgIGNsYWltYW50SWQ6IGNsYWltYW50LmlkLFxyXG4gICAgICAgICAgc2hhcmVkS2V5SWQ6IGNsYWltYW50LmtleUlkLFxyXG4gICAgICAgICAgc2hhcmVkQ2lwaGVyRGF0YSxcclxuICAgICAgICB9LFxyXG4gICAgICB9LFxyXG4gICAgfSk7XHJcbiAgICByZXR1cm4gcmVzLnVwZGF0ZVNjZW5hcmlvQ2xhaW1hbnQuY2xhaW1hbnQuaWQ7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgYXN5bmMgZGVsZXRlQ2xhaW1hbnQoY2xhaW1hbnRJZDogc3RyaW5nKTogUHJvbWlzZTx2b2lkPiB7XHJcbiAgICBhd2FpdCB0aGlzLmxyQXBvbGxvLm11dGF0ZTxhbnk+KHtcclxuICAgICAgbXV0YXRpb246IERlbGV0ZVNjZW5hcmlvQ2xhaW1hbnRNdXRhdGlvbixcclxuICAgICAgdmFyaWFibGVzOiB7IGlucHV0OiB7IGNsYWltYW50SWQgfSB9LFxyXG4gICAgfSk7XHJcbiAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NlbmFyaW8tY2xhaW1hbnQudHlwZXMuanMiLCJzb3VyY2VSb290IjoiQzovUHJvamVjdHMvdGVzdC9wcm9qZWN0cy9jb3JlL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9zY2VuYXJpby9jbGFpbWFudHMvc2NlbmFyaW8tY2xhaW1hbnQudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRydXN0ZWRQYXJ0eSB9IGZyb20gJy4uLy4uL3RydXN0ZWQtcGFydGllcy90cnVzdGVkLXBhcnR5LnR5cGVzJztcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgQ2xhaW1hbnQge1xyXG4gIGlkOiBzdHJpbmc7XHJcbiAga2V5SWQ6IHN0cmluZztcclxuICB0cnVzdGVkUGFydHk6IFRydXN0ZWRQYXJ0eTtcclxuICBtZXNzYWdlPzogc3RyaW5nO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEFkZFNjZW5hcmlvQ2xhaW1hbnQge1xyXG4gIHNjZW5hcmlvSWQ6IHN0cmluZztcclxuICB0cnVzdGVkUGFydHlJZDogc3RyaW5nO1xyXG4gIHRydXN0ZWRQYXJ0eVNoYXJlZEtleUlkOiBzdHJpbmc7XHJcbiAgcGxhaW5TaGFyZWRDaXBoZXJEYXRhOiBvYmplY3Q7XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgVXBkYXRlU2NlbmFyaW9DbGFpbWFudCB7XHJcbiAgaWQ6IHN0cmluZztcclxuICBrZXlJZDogc3RyaW5nO1xyXG4gIHBsYWluU2hhcmVkQ2lwaGVyRGF0YTogb2JqZWN0O1xyXG59XHJcbiJdfQ==
|