@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,117 @@
|
|
|
1
|
+
import { __awaiter, __decorate } from "tslib";
|
|
2
|
+
import { Injectable, NgZone } from '@angular/core';
|
|
3
|
+
import { EncryptionService } from '../cryptography/encryption.service';
|
|
4
|
+
import { KeyGraphService } from '../cryptography/key-graph.service';
|
|
5
|
+
import { KeyService } from '../cryptography/key.service';
|
|
6
|
+
import { RunOutsideAngular } from '../_common/run-outside-angular';
|
|
7
|
+
import { LrGraphQLService, LrMutation } from './lr-graphql';
|
|
8
|
+
import { GetOwnedContactCardKeyIdsQuery, GetReceivedContactCardKeyIdQuery, UpdateOwnedContactCardMutation, UpdateReceivedContactCardMutation, } from './shared-contact-card2.gql';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
import * as i1 from "../cryptography/key.service";
|
|
11
|
+
import * as i2 from "../cryptography/key-graph.service";
|
|
12
|
+
import * as i3 from "../cryptography/encryption.service";
|
|
13
|
+
import * as i4 from "./lr-graphql/lr-graphql.service";
|
|
14
|
+
let SharedContactCard2Service = class SharedContactCard2Service {
|
|
15
|
+
constructor(ngZone, keyService, keyGraph, encryptionService, lrGraphQL) {
|
|
16
|
+
this.ngZone = ngZone;
|
|
17
|
+
this.keyService = keyService;
|
|
18
|
+
this.keyGraph = keyGraph;
|
|
19
|
+
this.encryptionService = encryptionService;
|
|
20
|
+
this.lrGraphQL = lrGraphQL;
|
|
21
|
+
}
|
|
22
|
+
getOwnedContactCardKeyIds(id) {
|
|
23
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
24
|
+
const { ownedContactCard: cc } = yield this.lrGraphQL.query({
|
|
25
|
+
query: GetOwnedContactCardKeyIdsQuery,
|
|
26
|
+
variables: {
|
|
27
|
+
id,
|
|
28
|
+
},
|
|
29
|
+
});
|
|
30
|
+
return {
|
|
31
|
+
sharedKeyId: cc.sharedKey.id,
|
|
32
|
+
ownerKeyId: cc.ownerKey.id,
|
|
33
|
+
};
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
getReceivedContactCardKeyId(id) {
|
|
37
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
38
|
+
return (yield this.lrGraphQL.query({
|
|
39
|
+
query: GetReceivedContactCardKeyIdQuery,
|
|
40
|
+
variables: {
|
|
41
|
+
id,
|
|
42
|
+
},
|
|
43
|
+
})).receivedContactCard.receiverKey.id;
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
updateOwnedContactCard({ id, ownerKeyId, sharedKeyId, ownerPlainDataJson, ownerCipherDataClearJson, sharedCipherDataClearJson, }) {
|
|
47
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
48
|
+
let ownerKey;
|
|
49
|
+
let sharedKey;
|
|
50
|
+
try {
|
|
51
|
+
ownerKey = yield this.keyGraph.getKey(ownerKeyId);
|
|
52
|
+
sharedKey = yield this.keyGraph.getKey(sharedKeyId);
|
|
53
|
+
}
|
|
54
|
+
catch (error) {
|
|
55
|
+
const keys = yield this.getOwnedContactCardKeyIds(id);
|
|
56
|
+
// try again
|
|
57
|
+
ownerKey = yield this.keyGraph.getKey(keys.ownerKeyId);
|
|
58
|
+
sharedKey = yield this.keyGraph.getKey(keys.sharedKeyId);
|
|
59
|
+
}
|
|
60
|
+
const sigPxk = yield this.keyService.getCurrentSigPxk();
|
|
61
|
+
const sharedCipherData = yield this.encryptionService.encrypt(sharedKey.jwk, sharedCipherDataClearJson);
|
|
62
|
+
const sharedCipherDataSig = JSON.stringify(yield this.encryptionService.sign(sigPxk.jwk, sharedCipherData));
|
|
63
|
+
const ownerPlainDataSig = JSON.stringify(yield this.encryptionService.sign(sigPxk.jwk, ownerPlainDataJson));
|
|
64
|
+
const ownerCipherData = yield this.encryptionService.encryptToString(ownerKey.jwk, ownerCipherDataClearJson);
|
|
65
|
+
return new LrMutation({
|
|
66
|
+
mutation: UpdateOwnedContactCardMutation,
|
|
67
|
+
variables: {
|
|
68
|
+
input: {
|
|
69
|
+
id,
|
|
70
|
+
ownerCipherData,
|
|
71
|
+
ownerKeyId: ownerKey.id,
|
|
72
|
+
sharedCipherDataSig,
|
|
73
|
+
sharedKeyId: sharedKey.id,
|
|
74
|
+
sigPxkId: sigPxk.id,
|
|
75
|
+
ownerPlainDataSig,
|
|
76
|
+
},
|
|
77
|
+
},
|
|
78
|
+
});
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
updateReceivedContactCard({ id, receiverKeyId, receiverCipherDataClearJson, }) {
|
|
82
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
83
|
+
const receiverKey = yield this.keyGraph.getKey(receiverKeyId, () => this.getReceivedContactCardKeyId(id));
|
|
84
|
+
const receiverCipherData = yield this.encryptionService.encryptToString(receiverKey.jwk, receiverCipherDataClearJson);
|
|
85
|
+
return new LrMutation({
|
|
86
|
+
mutation: UpdateReceivedContactCardMutation,
|
|
87
|
+
variables: {
|
|
88
|
+
input: {
|
|
89
|
+
id,
|
|
90
|
+
receiverCipherData,
|
|
91
|
+
receiverKeyId: receiverKey.id,
|
|
92
|
+
},
|
|
93
|
+
},
|
|
94
|
+
});
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
};
|
|
98
|
+
SharedContactCard2Service.ɵprov = i0.ɵɵdefineInjectable({ factory: function SharedContactCard2Service_Factory() { return new SharedContactCard2Service(i0.ɵɵinject(i0.NgZone), i0.ɵɵinject(i1.KeyService), i0.ɵɵinject(i2.KeyGraphService), i0.ɵɵinject(i3.EncryptionService), i0.ɵɵinject(i4.LrGraphQLService)); }, token: SharedContactCard2Service, providedIn: "root" });
|
|
99
|
+
SharedContactCard2Service.decorators = [
|
|
100
|
+
{ type: Injectable, args: [{
|
|
101
|
+
providedIn: 'root',
|
|
102
|
+
},] }
|
|
103
|
+
];
|
|
104
|
+
SharedContactCard2Service.ctorParameters = () => [
|
|
105
|
+
{ type: NgZone },
|
|
106
|
+
{ type: KeyService },
|
|
107
|
+
{ type: KeyGraphService },
|
|
108
|
+
{ type: EncryptionService },
|
|
109
|
+
{ type: LrGraphQLService }
|
|
110
|
+
];
|
|
111
|
+
SharedContactCard2Service = __decorate([
|
|
112
|
+
RunOutsideAngular({
|
|
113
|
+
ngZoneName: 'ngZone',
|
|
114
|
+
})
|
|
115
|
+
], SharedContactCard2Service);
|
|
116
|
+
export { SharedContactCard2Service };
|
|
117
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"shared-contact-card2.service.js","sourceRoot":"C:/Projects/test/projects/core/src/","sources":["lib/api/shared-contact-card2.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, NgZone } from '@angular/core';\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 { RunOutsideAngular } from '../_common/run-outside-angular';\r\nimport {\r\n  ContactCardReceiverCipherData,\r\n  SendContactCardInput,\r\n} from './key-exchange2.service';\r\nimport { LrGraphQLService, LrMutation } from './lr-graphql';\r\nimport {\r\n  GetOwnedContactCardKeyIdsQuery,\r\n  GetReceivedContactCardKeyIdQuery,\r\n  UpdateOwnedContactCardMutation,\r\n  UpdateReceivedContactCardMutation,\r\n} from './shared-contact-card2.gql';\r\nimport { LrRelayIdInput } from './types';\r\n\r\nexport interface UpdateOwnedContactCardInput extends SendContactCardInput {\r\n  id: LrRelayIdInput;\r\n  ownerKeyId?: LrRelayIdInput;\r\n  sharedKeyId?: LrRelayIdInput;\r\n}\r\n\r\nexport interface UpdateReceivedContactCardInput\r\n  extends ContactCardReceiverCipherData {\r\n  id: LrRelayIdInput;\r\n  receiverKeyId?: LrRelayIdInput;\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 SharedContactCard2Service {\r\n  constructor(\r\n    private ngZone: NgZone,\r\n    private keyService: KeyService,\r\n    private keyGraph: KeyGraphService,\r\n    private encryptionService: EncryptionService,\r\n    private lrGraphQL: LrGraphQLService\r\n  ) {}\r\n\r\n  private async getOwnedContactCardKeyIds(id: LrRelayIdInput) {\r\n    const { ownedContactCard: cc } = await this.lrGraphQL.query({\r\n      query: GetOwnedContactCardKeyIdsQuery,\r\n      variables: {\r\n        id,\r\n      },\r\n    });\r\n\r\n    return {\r\n      sharedKeyId: cc.sharedKey.id,\r\n      ownerKeyId: cc.ownerKey.id,\r\n    };\r\n  }\r\n\r\n  private async getReceivedContactCardKeyId(id: LrRelayIdInput) {\r\n    return (\r\n      await this.lrGraphQL.query({\r\n        query: GetReceivedContactCardKeyIdQuery,\r\n        variables: {\r\n          id,\r\n        },\r\n      })\r\n    ).receivedContactCard.receiverKey.id;\r\n  }\r\n\r\n  async updateOwnedContactCard({\r\n    id,\r\n    ownerKeyId,\r\n    sharedKeyId,\r\n    ownerPlainDataJson,\r\n    ownerCipherDataClearJson,\r\n    sharedCipherDataClearJson,\r\n  }: UpdateOwnedContactCardInput) {\r\n    let ownerKey: Key;\r\n    let sharedKey: Key;\r\n\r\n    try {\r\n      ownerKey = await this.keyGraph.getKey(ownerKeyId);\r\n      sharedKey = await this.keyGraph.getKey(sharedKeyId);\r\n    } catch (error) {\r\n      const keys = await this.getOwnedContactCardKeyIds(id);\r\n\r\n      // try again\r\n      ownerKey = await this.keyGraph.getKey(keys.ownerKeyId);\r\n      sharedKey = await this.keyGraph.getKey(keys.sharedKeyId);\r\n    }\r\n\r\n    const sigPxk = await this.keyService.getCurrentSigPxk();\r\n\r\n    const sharedCipherData = await this.encryptionService.encrypt(\r\n      sharedKey.jwk,\r\n      sharedCipherDataClearJson\r\n    );\r\n    const sharedCipherDataSig = JSON.stringify(\r\n      await this.encryptionService.sign(sigPxk.jwk, sharedCipherData)\r\n    );\r\n\r\n    const ownerPlainDataSig = JSON.stringify(\r\n      await this.encryptionService.sign(sigPxk.jwk, ownerPlainDataJson)\r\n    );\r\n\r\n    const ownerCipherData = await this.encryptionService.encryptToString(\r\n      ownerKey.jwk,\r\n      ownerCipherDataClearJson\r\n    );\r\n\r\n    return new LrMutation({\r\n      mutation: UpdateOwnedContactCardMutation,\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  async updateReceivedContactCard({\r\n    id,\r\n    receiverKeyId,\r\n    receiverCipherDataClearJson,\r\n  }: UpdateReceivedContactCardInput) {\r\n    const receiverKey = await this.keyGraph.getKey(receiverKeyId, () =>\r\n      this.getReceivedContactCardKeyId(id)\r\n    );\r\n\r\n    const receiverCipherData = await this.encryptionService.encryptToString(\r\n      receiverKey.jwk,\r\n      receiverCipherDataClearJson\r\n    );\r\n\r\n    return new LrMutation({\r\n      mutation: UpdateReceivedContactCardMutation,\r\n      variables: {\r\n        input: {\r\n          id,\r\n          receiverCipherData,\r\n          receiverKeyId: receiverKey.id,\r\n        },\r\n      },\r\n    });\r\n  }\r\n}\r\n"]}
|
|
@@ -0,0 +1,146 @@
|
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
2
|
+
import { Injectable } from '@angular/core';
|
|
3
|
+
import { AuthClass } from '@aws-amplify/auth/lib-esm/Auth';
|
|
4
|
+
import { Apollo } from 'apollo-angular';
|
|
5
|
+
import gql from 'graphql-tag';
|
|
6
|
+
import * as moment_ from 'moment';
|
|
7
|
+
import { LrErrorCode, LrException, handleApolloError, } from '../_common/exceptions';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "@aws-amplify/auth/lib-esm/Auth";
|
|
10
|
+
import * as i2 from "apollo-angular";
|
|
11
|
+
// "why?" you ask: https://stackoverflow.com/questions/59735280/angular-8-moment-error-cannot-call-a-namespace-moment
|
|
12
|
+
const moment = moment_;
|
|
13
|
+
export const ServerTimeQuery = gql `
|
|
14
|
+
query {
|
|
15
|
+
serverTime {
|
|
16
|
+
timestamp
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
`;
|
|
20
|
+
export class TimeService {
|
|
21
|
+
constructor(auth, apollo) {
|
|
22
|
+
this.auth = auth;
|
|
23
|
+
this.apollo = apollo;
|
|
24
|
+
this.VERIFY_ENABLED = true;
|
|
25
|
+
this.MAX_DIFF_MSEC = moment
|
|
26
|
+
.duration({ seconds: 30 })
|
|
27
|
+
.asMilliseconds();
|
|
28
|
+
this.offsetMs = null; // Millisecond offset of local clock.
|
|
29
|
+
this.verified = false; // Verified with independent time source
|
|
30
|
+
}
|
|
31
|
+
getAccessToken() {
|
|
32
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
33
|
+
try {
|
|
34
|
+
return (yield this.auth.currentAuthenticatedUser())
|
|
35
|
+
.getSignInUserSession()
|
|
36
|
+
.getAccessToken()
|
|
37
|
+
.getJwtToken();
|
|
38
|
+
}
|
|
39
|
+
catch (error) {
|
|
40
|
+
return ''; // Not authenticated
|
|
41
|
+
}
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
// Get time from independent source to confirm.
|
|
45
|
+
verifyCognito() {
|
|
46
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
47
|
+
const accessToken = yield this.getAccessToken();
|
|
48
|
+
if (!accessToken) {
|
|
49
|
+
return;
|
|
50
|
+
}
|
|
51
|
+
// Request headers from AWS Amplify Auth lib
|
|
52
|
+
// accept: */*
|
|
53
|
+
// accept-encoding: gzip, deflate, br
|
|
54
|
+
// accept-language: en-GB,en-US;q=0.9,en;q=0.8
|
|
55
|
+
// cache-control: no-cache
|
|
56
|
+
// content-length: 1089
|
|
57
|
+
// content-type: application/x-amz-json-1.1
|
|
58
|
+
// origin: http://localhost:4200
|
|
59
|
+
// pragma: no-cache
|
|
60
|
+
// referer: http://localhost:4200/
|
|
61
|
+
// sec-fetch-dest: empty
|
|
62
|
+
// sec-fetch-mode: cors
|
|
63
|
+
// sec-fetch-site: cross-site
|
|
64
|
+
// user-agent: Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.132 Safari/537.36
|
|
65
|
+
// x-amz-target: AWSCognitoIdentityProviderService.GetUser
|
|
66
|
+
// x-amz-user-agent: aws-amplify/0.1.x js
|
|
67
|
+
// We are only interested in the Date field.
|
|
68
|
+
// AZ: I suppose we could use any end-point that provides a reliable Date field in the header. And we don't
|
|
69
|
+
// need to be authenticated. Even a 400 response would have a Date header. But the worry is that AWS might
|
|
70
|
+
// think it's some sort of attack, and block the IP or domain. At least in an authenticated call it can't be
|
|
71
|
+
// seen as illegitimate.
|
|
72
|
+
const response = yield fetch('https://cognito-idp.ap-southeast-2.amazonaws.com/', {
|
|
73
|
+
method: 'POST',
|
|
74
|
+
mode: 'cors',
|
|
75
|
+
cache: 'no-cache',
|
|
76
|
+
headers: {
|
|
77
|
+
'x-amz-target': 'AWSCognitoIdentityProviderService.GetUser',
|
|
78
|
+
'x-amz-user-agent': 'aws-amplify/0.1.x js',
|
|
79
|
+
'Content-Type': 'application/x-amz-json-1.1',
|
|
80
|
+
},
|
|
81
|
+
// redirect: 'follow', // manual, *follow, error
|
|
82
|
+
// referrerPolicy: 'no-referrer', // no-referrer, *no-referrer-when-downgrade, origin, origin-when-cross-origin, same-origin, strict-origin, strict-origin-when-cross-origin, unsafe-url
|
|
83
|
+
body: JSON.stringify({
|
|
84
|
+
AccessToken: accessToken,
|
|
85
|
+
}),
|
|
86
|
+
});
|
|
87
|
+
const now = Date.now();
|
|
88
|
+
const verifyTime = moment(response.headers.get('Date')).valueOf();
|
|
89
|
+
const serverTime = now + this.offsetMs;
|
|
90
|
+
const diff = Math.abs(serverTime - verifyTime);
|
|
91
|
+
if (diff > this.MAX_DIFF_MSEC) {
|
|
92
|
+
throw new LrException({
|
|
93
|
+
code: LrErrorCode.BadTimeSync,
|
|
94
|
+
message: `Server time does not match independent source. ServerTime: ${serverTime}, Cognito time: ${verifyTime}`,
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
this.verified = true;
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
refresh() {
|
|
101
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
102
|
+
const start = Date.now();
|
|
103
|
+
const res = yield this.apollo
|
|
104
|
+
.query({ query: ServerTimeQuery })
|
|
105
|
+
.toPromise();
|
|
106
|
+
const end = Date.now();
|
|
107
|
+
handleApolloError(res.errors);
|
|
108
|
+
const serverTime = parseInt(res.data.serverTime.timestamp, 10);
|
|
109
|
+
const roundtrip = end - start;
|
|
110
|
+
this.offsetMs = serverTime - (start + roundtrip / 2);
|
|
111
|
+
if (this.VERIFY_ENABLED) {
|
|
112
|
+
yield this.verifyCognito();
|
|
113
|
+
}
|
|
114
|
+
});
|
|
115
|
+
}
|
|
116
|
+
serverNow() {
|
|
117
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
118
|
+
let needsRefresh = false;
|
|
119
|
+
// First call
|
|
120
|
+
if (this.offsetMs === null) {
|
|
121
|
+
needsRefresh = true;
|
|
122
|
+
}
|
|
123
|
+
if (this.VERIFY_ENABLED) {
|
|
124
|
+
// logged in but not yet verified time matches.
|
|
125
|
+
if (!this.verified && (yield this.getAccessToken())) {
|
|
126
|
+
needsRefresh = true;
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
if (needsRefresh) {
|
|
130
|
+
yield this.refresh();
|
|
131
|
+
}
|
|
132
|
+
return Date.now() + this.offsetMs;
|
|
133
|
+
});
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
TimeService.ɵprov = i0.ɵɵdefineInjectable({ factory: function TimeService_Factory() { return new TimeService(i0.ɵɵinject(i1.AuthClass), i0.ɵɵinject(i2.Apollo)); }, token: TimeService, providedIn: "root" });
|
|
137
|
+
TimeService.decorators = [
|
|
138
|
+
{ type: Injectable, args: [{
|
|
139
|
+
providedIn: 'root',
|
|
140
|
+
},] }
|
|
141
|
+
];
|
|
142
|
+
TimeService.ctorParameters = () => [
|
|
143
|
+
{ type: AuthClass },
|
|
144
|
+
{ type: Apollo }
|
|
145
|
+
];
|
|
146
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time.service.js","sourceRoot":"C:/Projects/test/projects/core/src/","sources":["lib/api/time.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { AuthClass } from '@aws-amplify/auth/lib-esm/Auth';\r\nimport { Apollo } from 'apollo-angular';\r\nimport gql from 'graphql-tag';\r\nimport * as moment_ from 'moment';\r\nimport {\r\n  LrErrorCode,\r\n  LrException,\r\n  handleApolloError,\r\n} from '../_common/exceptions';\r\n// \"why?\" you ask: https://stackoverflow.com/questions/59735280/angular-8-moment-error-cannot-call-a-namespace-moment\r\nconst moment = moment_;\r\n\r\nexport const ServerTimeQuery = gql`\r\n  query {\r\n    serverTime {\r\n      timestamp\r\n    }\r\n  }\r\n`;\r\n\r\ninterface ServerTime {\r\n  timestamp: string;\r\n}\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class TimeService {\r\n  public VERIFY_ENABLED = true;\r\n  private readonly MAX_DIFF_MSEC = moment\r\n    .duration({ seconds: 30 })\r\n    .asMilliseconds();\r\n\r\n  offsetMs: number = null; // Millisecond offset of local clock.\r\n  verified = false; // Verified with independent time source\r\n\r\n  constructor(private auth: AuthClass, private apollo: Apollo) {}\r\n\r\n  private async getAccessToken(): Promise<string> {\r\n    try {\r\n      return (await this.auth.currentAuthenticatedUser())\r\n        .getSignInUserSession()\r\n        .getAccessToken()\r\n        .getJwtToken();\r\n    } catch (error) {\r\n      return ''; // Not authenticated\r\n    }\r\n  }\r\n\r\n  // Get time from independent source to confirm.\r\n  private async verifyCognito(): Promise<void> {\r\n    const accessToken = await this.getAccessToken();\r\n    if (!accessToken) {\r\n      return;\r\n    }\r\n\r\n    // Request headers from AWS Amplify Auth lib\r\n    // accept: */*\r\n    // accept-encoding: gzip, deflate, br\r\n    // accept-language: en-GB,en-US;q=0.9,en;q=0.8\r\n    // cache-control: no-cache\r\n    // content-length: 1089\r\n    // content-type: application/x-amz-json-1.1\r\n    // origin: http://localhost:4200\r\n    // pragma: no-cache\r\n    // referer: http://localhost:4200/\r\n    // sec-fetch-dest: empty\r\n    // sec-fetch-mode: cors\r\n    // sec-fetch-site: cross-site\r\n    // user-agent: Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.132 Safari/537.36\r\n    // x-amz-target: AWSCognitoIdentityProviderService.GetUser\r\n    // x-amz-user-agent: aws-amplify/0.1.x js\r\n\r\n    // We are only interested in the Date field.\r\n    // AZ: I suppose we could use any end-point that provides a reliable Date field in the header. And we don't\r\n    // need to be authenticated. Even a 400 response would have a Date header. But the worry is that AWS might\r\n    // think it's some sort of attack, and block the IP or domain. At least in an authenticated call it can't be\r\n    // seen as illegitimate.\r\n    const response = await fetch(\r\n      'https://cognito-idp.ap-southeast-2.amazonaws.com/',\r\n      {\r\n        method: 'POST', // *GET, POST, PUT, DELETE, etc.\r\n        mode: 'cors', // no-cors, *cors, same-origin\r\n        cache: 'no-cache', // *default, no-cache, reload, force-cache, only-if-cached\r\n        headers: {\r\n          'x-amz-target': 'AWSCognitoIdentityProviderService.GetUser',\r\n          'x-amz-user-agent': 'aws-amplify/0.1.x js',\r\n          'Content-Type': 'application/x-amz-json-1.1',\r\n        },\r\n        // redirect: 'follow', // manual, *follow, error\r\n        // referrerPolicy: 'no-referrer', // no-referrer, *no-referrer-when-downgrade, origin, origin-when-cross-origin, same-origin, strict-origin, strict-origin-when-cross-origin, unsafe-url\r\n        body: JSON.stringify({\r\n          AccessToken: accessToken,\r\n        }), // body data type must match \"Content-Type\" header\r\n      }\r\n    );\r\n\r\n    const now = Date.now();\r\n\r\n    const verifyTime = moment(response.headers.get('Date')).valueOf();\r\n    const serverTime = now + this.offsetMs;\r\n    const diff = Math.abs(serverTime - verifyTime);\r\n\r\n    if (diff > this.MAX_DIFF_MSEC) {\r\n      throw new LrException({\r\n        code: LrErrorCode.BadTimeSync,\r\n        message: `Server time does not match independent source. ServerTime: ${serverTime}, Cognito time: ${verifyTime}`,\r\n      });\r\n    }\r\n\r\n    this.verified = true;\r\n  }\r\n\r\n  private async refresh(): Promise<void> {\r\n    const start = Date.now();\r\n    const res = await this.apollo\r\n      .query<{ serverTime: ServerTime }>({ query: ServerTimeQuery })\r\n      .toPromise();\r\n    const end = Date.now();\r\n\r\n    handleApolloError(res.errors);\r\n\r\n    const serverTime = parseInt(res.data.serverTime.timestamp, 10);\r\n\r\n    const roundtrip = end - start;\r\n    this.offsetMs = serverTime - (start + roundtrip / 2);\r\n\r\n    if (this.VERIFY_ENABLED) {\r\n      await this.verifyCognito();\r\n    }\r\n  }\r\n\r\n  async serverNow(): Promise<number> {\r\n    let needsRefresh = false;\r\n\r\n    // First call\r\n    if (this.offsetMs === null) {\r\n      needsRefresh = true;\r\n    }\r\n\r\n    if (this.VERIFY_ENABLED) {\r\n      // logged in but not yet verified time matches.\r\n      if (!this.verified && (await this.getAccessToken())) {\r\n        needsRefresh = true;\r\n      }\r\n    }\r\n\r\n    if (needsRefresh) {\r\n      await this.refresh();\r\n    }\r\n\r\n    return Date.now() + this.offsetMs;\r\n  }\r\n}\r\n"]}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
// ------------------------------------------------------
|
|
2
|
+
// Basic types
|
|
3
|
+
// ------------------------------------------------------
|
|
4
|
+
// These types map directory to types of the same name in graphql.
|
|
5
|
+
// We use these aliases in case in the future we wish to reify the types and do
|
|
6
|
+
// additional automated conversion.
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JhcGhxbC50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiJDOi9Qcm9qZWN0cy90ZXN0L3Byb2plY3RzL2NvcmUvc3JjLyIsInNvdXJjZXMiOlsibGliL2FwaS90eXBlcy9ncmFwaHFsLnR5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLHlEQUF5RDtBQUN6RCxjQUFjO0FBQ2QseURBQXlEO0FBQ3pELGtFQUFrRTtBQUNsRSwrRUFBK0U7QUFDL0UsbUNBQW1DIiwic291cmNlc0NvbnRlbnQiOlsiLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tXHJcbi8vIEJhc2ljIHR5cGVzXHJcbi8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLVxyXG4vLyBUaGVzZSB0eXBlcyBtYXAgZGlyZWN0b3J5IHRvIHR5cGVzIG9mIHRoZSBzYW1lIG5hbWUgaW4gZ3JhcGhxbC5cclxuLy8gV2UgdXNlIHRoZXNlIGFsaWFzZXMgaW4gY2FzZSBpbiB0aGUgZnV0dXJlIHdlIHdpc2ggdG8gcmVpZnkgdGhlIHR5cGVzIGFuZCBkb1xyXG4vLyBhZGRpdGlvbmFsIGF1dG9tYXRlZCBjb252ZXJzaW9uLlxyXG5cclxuZXhwb3J0IHR5cGUgSUQgPSBzdHJpbmc7XHJcbi8vIFNlcnZlciByZXF1aXJlcyB0aGlzIHRvIGhhdmUgY2VydGFpbiBmb3JtYXQuIEJ1dCBjbGllbnRcclxuLy8ganVzdCB0cmVhdHMgdGhpcyBhcyBhbiBvcGFxdWUgc3RyaW5nLlxyXG5leHBvcnQgdHlwZSBMclJlbGF5SWRJbnB1dCA9IHN0cmluZztcclxuZXhwb3J0IHR5cGUgRGF0ZVRpbWUgPSBzdHJpbmc7XHJcbi8vIFRoaXMgaXMgYmFzaWNhbGx5IHRoZSByZXN1bHRzIG9mOiBKU09OLnN0cmluZ2lmeShvYmopXHJcbi8vIFNlcnZlciB2YWxpZGF0ZWQgdG8gbWFrZSBzdXJlIGl0IGNhbiBKU09OLnBhcnNlKCkgdGhpcy5cclxuZXhwb3J0IHR5cGUgTHJKU09OU3RyaW5nID0gc3RyaW5nO1xyXG4vLyBKU09OU3RyaW5nIGlzIGEgdHlwZSBmcm9tIGdyYXBoZW5lLiBEQiBKU09OIGZpZWxkcyBtYXBzIHRvIHRoaXMgdHlwZVxyXG4vLyBhdXRvbWF0aWNhbGx5LlxyXG4vLyBXaGVyZSBhcyBMckpTT05TdHJpbmcgaXMgb3V0IGN1c3RvbSBpbXBsZW1lbnRhdGlvbiBmb3IgaW5wdXQgdmFyaWFibGVzLlxyXG5leHBvcnQgdHlwZSBKU09OU3RyaW5nID0gc3RyaW5nO1xyXG5leHBvcnQgdHlwZSBMckVtYWlsID0gc3RyaW5nO1xyXG5leHBvcnQgdHlwZSBHZW5lcmljU2NhbGFyID0gYW55O1xyXG5leHBvcnQgdHlwZSBVVUlEID0gc3RyaW5nO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBOb2RlIHtcclxuICBpZD86IHN0cmluZztcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBUaW1lU3RhbXBlZCB7XHJcbiAgY3JlYXRlZD86IERhdGVUaW1lO1xyXG4gIG1vZGlmaWVkPzogRGF0ZVRpbWU7XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgRWRnZTxOb2RlVHlwZSBleHRlbmRzIE5vZGU+IHtcclxuICBub2RlPzogTm9kZVR5cGU7XHJcbiAgY3Vyc29yPzogc3RyaW5nO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIENvbm5lY3Rpb248Tm9kZVR5cGU+IHtcclxuICBwYWdlSW5mbz86IFBhZ2VJbmZvO1xyXG4gIGVkZ2VzPzogRWRnZTxOb2RlVHlwZT5bXTtcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBQYWdlSW5mbyB7XHJcbiAgaGFzTmV4dFBhZ2U/OiBib29sZWFuO1xyXG4gIGhhc1ByZXZpb3VzUGFnZT86IGJvb2xlYW47XHJcbiAgc3RhcnRDdXJzb3I/OiBzdHJpbmc7XHJcbiAgZW5kQ3Vyc29yPzogc3RyaW5nO1xyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export * from './graphql.types';
|
|
2
|
+
export * from './lr-graphql.types';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiQzovUHJvamVjdHMvdGVzdC9wcm9qZWN0cy9jb3JlL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9hcGkvdHlwZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxpQkFBaUIsQ0FBQztBQUNoQyxjQUFjLG9CQUFvQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9ncmFwaHFsLnR5cGVzJztcclxuZXhwb3J0ICogZnJvbSAnLi9sci1ncmFwaHFsLnR5cGVzJztcclxuIl19
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
export var AccessRoleChoice;
|
|
2
|
+
(function (AccessRoleChoice) {
|
|
3
|
+
AccessRoleChoice["READER"] = "READER";
|
|
4
|
+
AccessRoleChoice["WRITER"] = "WRITER";
|
|
5
|
+
AccessRoleChoice["ADMIN"] = "ADMIN";
|
|
6
|
+
AccessRoleChoice["DENY"] = "DENY";
|
|
7
|
+
AccessRoleChoice["OWNER"] = "OWNER";
|
|
8
|
+
})(AccessRoleChoice || (AccessRoleChoice = {}));
|
|
9
|
+
export var AccessRoleMethod;
|
|
10
|
+
(function (AccessRoleMethod) {
|
|
11
|
+
AccessRoleMethod["inherited"] = "inherited";
|
|
12
|
+
AccessRoleMethod["direct"] = "direct";
|
|
13
|
+
})(AccessRoleMethod || (AccessRoleMethod = {}));
|
|
14
|
+
export var FileVersionOperation;
|
|
15
|
+
(function (FileVersionOperation) {
|
|
16
|
+
FileVersionOperation["CREATE"] = "CREATE";
|
|
17
|
+
FileVersionOperation["READ"] = "READ";
|
|
18
|
+
FileVersionOperation["UPDATE"] = "UPDATE";
|
|
19
|
+
FileVersionOperation["REVERT"] = "REVERT";
|
|
20
|
+
FileVersionOperation["DELETE"] = "DELETE";
|
|
21
|
+
})(FileVersionOperation || (FileVersionOperation = {}));
|
|
22
|
+
export var KeyExchangeOtkState;
|
|
23
|
+
(function (KeyExchangeOtkState) {
|
|
24
|
+
KeyExchangeOtkState["OTK_INITIATED"] = "OTK_INITIATED";
|
|
25
|
+
KeyExchangeOtkState["OTK_ACCEPTED"] = "OTK_ACCEPTED";
|
|
26
|
+
KeyExchangeOtkState["OTK_COMPLETED"] = "OTK_COMPLETED";
|
|
27
|
+
})(KeyExchangeOtkState || (KeyExchangeOtkState = {}));
|
|
28
|
+
export var KeyExchangeState;
|
|
29
|
+
(function (KeyExchangeState) {
|
|
30
|
+
KeyExchangeState["IN_PROGRESS"] = "IN_PROGRESS";
|
|
31
|
+
KeyExchangeState["COMPLETED"] = "COMPLETED";
|
|
32
|
+
KeyExchangeState["DECLINED"] = "DECLINED";
|
|
33
|
+
KeyExchangeState["CANCELLED"] = "CANCELLED";
|
|
34
|
+
KeyExchangeState["DELETED"] = "DELETED";
|
|
35
|
+
})(KeyExchangeState || (KeyExchangeState = {}));
|
|
36
|
+
export var KeyExchangeMode;
|
|
37
|
+
(function (KeyExchangeMode) {
|
|
38
|
+
KeyExchangeMode["OTK"] = "OTK";
|
|
39
|
+
})(KeyExchangeMode || (KeyExchangeMode = {}));
|
|
40
|
+
export var TpAssemblyState;
|
|
41
|
+
(function (TpAssemblyState) {
|
|
42
|
+
TpAssemblyState["DISABLED"] = "DISABLED";
|
|
43
|
+
TpAssemblyState["ENABLED"] = "ENABLED";
|
|
44
|
+
TpAssemblyState["CLAIMED"] = "CLAIMED";
|
|
45
|
+
TpAssemblyState["APPROVED"] = "APPROVED";
|
|
46
|
+
TpAssemblyState["REJECTED"] = "REJECTED";
|
|
47
|
+
TpAssemblyState["EXPIRED"] = "EXPIRED";
|
|
48
|
+
TpAssemblyState["CANCELLED"] = "CANCELLED";
|
|
49
|
+
TpAssemblyState["RESET"] = "RESET";
|
|
50
|
+
})(TpAssemblyState || (TpAssemblyState = {}));
|
|
51
|
+
export var TpClaimState;
|
|
52
|
+
(function (TpClaimState) {
|
|
53
|
+
TpClaimState["CLAIMED"] = "CLAIMED";
|
|
54
|
+
TpClaimState["APPROVED"] = "APPROVED";
|
|
55
|
+
TpClaimState["REJECTED"] = "REJECTED";
|
|
56
|
+
TpClaimState["EXPIRED"] = "EXPIRED";
|
|
57
|
+
TpClaimState["CANCELLED"] = "CANCELLED";
|
|
58
|
+
TpClaimState["RESET"] = "RESET";
|
|
59
|
+
})(TpClaimState || (TpClaimState = {}));
|
|
60
|
+
export var TpClaimApproverState;
|
|
61
|
+
(function (TpClaimApproverState) {
|
|
62
|
+
TpClaimApproverState["CLAIMED"] = "CLAIMED";
|
|
63
|
+
TpClaimApproverState["APPROVED"] = "APPROVED";
|
|
64
|
+
TpClaimApproverState["REJECTED"] = "REJECTED";
|
|
65
|
+
})(TpClaimApproverState || (TpClaimApproverState = {}));
|
|
66
|
+
export var LockState;
|
|
67
|
+
(function (LockState) {
|
|
68
|
+
LockState["UNLOCKED"] = "UNLOCKED";
|
|
69
|
+
LockState["MUTEX_LOCKED"] = "MUTEX_LOCKED";
|
|
70
|
+
})(LockState || (LockState = {}));
|
|
71
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lr-graphql.types.js","sourceRoot":"C:/Projects/test/projects/core/src/","sources":["lib/api/types/lr-graphql.types.ts"],"names":[],"mappings":"AA+HA,MAAM,CAAN,IAAY,gBAMX;AAND,WAAY,gBAAgB;IAC1B,qCAAiB,CAAA;IACjB,qCAAiB,CAAA;IACjB,mCAAe,CAAA;IACf,iCAAa,CAAA;IACb,mCAAe,CAAA;AACjB,CAAC,EANW,gBAAgB,KAAhB,gBAAgB,QAM3B;AAED,MAAM,CAAN,IAAY,gBAGX;AAHD,WAAY,gBAAgB;IAC1B,2CAAuB,CAAA;IACvB,qCAAiB,CAAA;AACnB,CAAC,EAHW,gBAAgB,KAAhB,gBAAgB,QAG3B;AAYD,MAAM,CAAN,IAAY,oBAMX;AAND,WAAY,oBAAoB;IAC9B,yCAAiB,CAAA;IACjB,qCAAa,CAAA;IACb,yCAAiB,CAAA;IACjB,yCAAiB,CAAA;IACjB,yCAAiB,CAAA;AACnB,CAAC,EANW,oBAAoB,KAApB,oBAAoB,QAM/B;AAkBD,MAAM,CAAN,IAAY,mBAIX;AAJD,WAAY,mBAAmB;IAC7B,sDAA+B,CAAA;IAC/B,oDAA6B,CAAA;IAC7B,sDAA+B,CAAA;AACjC,CAAC,EAJW,mBAAmB,KAAnB,mBAAmB,QAI9B;AAoCD,MAAM,CAAN,IAAY,gBAMX;AAND,WAAY,gBAAgB;IAC1B,+CAA2B,CAAA;IAC3B,2CAAuB,CAAA;IACvB,yCAAqB,CAAA;IACrB,2CAAuB,CAAA;IACvB,uCAAmB,CAAA;AACrB,CAAC,EANW,gBAAgB,KAAhB,gBAAgB,QAM3B;AAED,MAAM,CAAN,IAAY,eAEX;AAFD,WAAY,eAAe;IACzB,8BAAW,CAAA;AACb,CAAC,EAFW,eAAe,KAAf,eAAe,QAE1B;AAoFD,MAAM,CAAN,IAAY,eASX;AATD,WAAY,eAAe;IACzB,wCAAqB,CAAA;IACrB,sCAAmB,CAAA;IACnB,sCAAmB,CAAA;IACnB,wCAAqB,CAAA;IACrB,wCAAqB,CAAA;IACrB,sCAAmB,CAAA;IACnB,0CAAuB,CAAA;IACvB,kCAAe,CAAA;AACjB,CAAC,EATW,eAAe,KAAf,eAAe,QAS1B;AAED,MAAM,CAAN,IAAY,YAOX;AAPD,WAAY,YAAY;IACtB,mCAAmB,CAAA;IACnB,qCAAqB,CAAA;IACrB,qCAAqB,CAAA;IACrB,mCAAmB,CAAA;IACnB,uCAAuB,CAAA;IACvB,+BAAe,CAAA;AACjB,CAAC,EAPW,YAAY,KAAZ,YAAY,QAOvB;AAED,MAAM,CAAN,IAAY,oBAIX;AAJD,WAAY,oBAAoB;IAC9B,2CAAmB,CAAA;IACnB,6CAAqB,CAAA;IACrB,6CAAqB,CAAA;AACvB,CAAC,EAJW,oBAAoB,KAApB,oBAAoB,QAI/B;AAmID,MAAM,CAAN,IAAY,SAGX;AAHD,WAAY,SAAS;IACnB,kCAAqB,CAAA;IACrB,0CAA6B,CAAA;AAC/B,CAAC,EAHW,SAAS,KAAT,SAAS,QAGpB","sourcesContent":["import { Time } from '@angular/common';\r\nimport {\r\n  Connection,\r\n  DateTime,\r\n  GenericScalar,\r\n  ID,\r\n  JSONString,\r\n  LrEmail,\r\n  Node,\r\n  TimeStamped,\r\n} from './graphql.types';\r\n\r\n// TODO: fill these types\r\nexport type UserStripeNode = any;\r\nexport type UserPlanNode = any;\r\nexport type UserDeleteNode = any;\r\nexport type FeaturesNode = any;\r\nexport type ScenarioNode = any;\r\nexport type SharedScenarioNode = any;\r\n\r\nexport type TpPasswordResetRequestNode = any;\r\n\r\nexport interface PassKeyNode extends Node, TimeStamped {\r\n  passKeyParams?: GenericScalar;\r\n  passIdpParams?: GenericScalar;\r\n  wrappedPassIdpVerifierPrk?: GenericScalar;\r\n}\r\n\r\nexport interface CurrentUserKeyNode extends Node, TimeStamped {\r\n  passKeys?: PassKeyNode[];\r\n  passKey?: PassKeyNode;\r\n  rootKey?: KeyNode;\r\n  masterKey?: KeyNode;\r\n  pxk?: KeyNode;\r\n  sigPxk?: KeyNode;\r\n}\r\n\r\n// ------------------------------------------------------\r\n// Node types\r\n// ------------------------------------------------------\r\nexport interface UserNode extends Node {\r\n  username?: string;\r\n  contactCards?: Connection<ContactCardNode>;\r\n  currentUserKey?: CurrentUserKeyNode;\r\n  ownedContactCard?: SharedContactCardNode;\r\n  receivedContactCard?: SharedContactCardNode;\r\n  isCurrentUser?: boolean;\r\n  haveTp?: boolean;\r\n  stripe?: UserStripeNode;\r\n  userPlans?: Connection<UserPlanNode>;\r\n  userDelete?: UserDeleteNode;\r\n  features?: FeaturesNode;\r\n}\r\n\r\nexport interface ServerTime {\r\n  timestamp?: string;\r\n}\r\n\r\nexport interface KeyNode extends Node, TimeStamped {\r\n  pbk?: string;\r\n}\r\n\r\nexport interface ContactCardNode extends Node, TimeStamped {\r\n  owner?: UserNode;\r\n  publicDataSig?: string;\r\n  publicSearchableSig?: string;\r\n  sigPxk?: KeyNode;\r\n  defaultFrom?: DateTime;\r\n  publicData?: string;\r\n  publicSearchable?: string;\r\n  cipherData?: string;\r\n  cipherDataClearJson?: any;\r\n  key?: KeyNode;\r\n  plainData?: string;\r\n  plainDataSig?: string;\r\n}\r\n\r\nexport interface DirectoryNode extends Node, TimeStamped {\r\n  plainMeta?: JSONString;\r\n  plainMetaJson?: any;\r\n  cipherMeta?: string;\r\n  cipherMetaClearJson?: any;\r\n  archived?: boolean;\r\n  keyId?: ID;\r\n  childFileLinks?: Connection<FileLinkNode>;\r\n  childDirectoryLinks?: Connection<DirectoryLinkNode>;\r\n  parentDirectoryLinks?: Connection<DirectoryLinkNode>;\r\n  nParentDirectoryLinks?: DirectoryLinkNodeLrNList;\r\n  descendants?: Descendants;\r\n  accessRoles?: AccessRole[];\r\n}\r\n\r\nexport interface FileNode extends Node, TimeStamped {\r\n  currentVersion?: FileVersionNode;\r\n  archived?: boolean;\r\n  versions?: Connection<FileVersionNode>;\r\n  keyId?: ID;\r\n  parentDirectoryLinks?: Connection<FileLinkNode>;\r\n  nParentDirectoryLinks?: FileLinkNodeLrNList;\r\n  accessRoles?: AccessRole[];\r\n}\r\n\r\nexport interface DirectoryLinkNode extends Node, TimeStamped {\r\n  parentDirectory?: DirectoryNode;\r\n  childDirectory?: DirectoryNode;\r\n}\r\n\r\nexport interface FileLinkNode extends Node, TimeStamped {\r\n  parentDirectory?: DirectoryNode;\r\n  childFile?: FileNode;\r\n}\r\n\r\nexport interface DirectoryLinkNodeLrNList {\r\n  list?: DirectoryLinkNode[];\r\n}\r\n\r\nexport interface FileLinkNodeLrNList {\r\n  list?: FileLinkNode[];\r\n}\r\n\r\nexport interface Descendants {\r\n  directories?: Connection<DirectoryNode>;\r\n  files?: Connection<FileNode>;\r\n  directoriesCount?: number;\r\n  filesCount?: number;\r\n}\r\n\r\nexport enum AccessRoleChoice {\r\n  READER = 'READER',\r\n  WRITER = 'WRITER',\r\n  ADMIN = 'ADMIN',\r\n  DENY = 'DENY',\r\n  OWNER = 'OWNER',\r\n}\r\n\r\nexport enum AccessRoleMethod {\r\n  inherited = 'inherited',\r\n  direct = 'direct',\r\n}\r\n\r\nexport interface AccessRole {\r\n  issuer?: UserNode;\r\n  subject?: UserNode;\r\n  role?: AccessRoleChoice;\r\n  method?: AccessRoleMethod;\r\n  inheritedFrom?: DirectoryNode;\r\n  trustedParty?: TpNode;\r\n  isIssuer?: boolean;\r\n}\r\n\r\nexport enum FileVersionOperation {\r\n  CREATE = 'CREATE',\r\n  READ = 'READ',\r\n  UPDATE = 'UPDATE',\r\n  REVERT = 'REVERT',\r\n  DELETE = 'DELETE',\r\n}\r\n\r\nexport interface FileVersionNode extends Node, TimeStamped {\r\n  file?: FileNode;\r\n  state?: FileStateNode;\r\n  operation?: FileVersionOperation;\r\n  author?: UserNode;\r\n}\r\nexport interface FileStateNode extends Node, TimeStamped {\r\n  plainMeta?: JSONString;\r\n  plainMetaJson?: any;\r\n  cipherMeta?: string;\r\n  cipherMetaClearJson?: any;\r\n  contentResource?: string;\r\n  versions?: Connection<FileVersionNode>;\r\n  keyId: ID;\r\n}\r\n\r\nexport enum KeyExchangeOtkState {\r\n  OTK_INITIATED = 'OTK_INITIATED',\r\n  OTK_ACCEPTED = 'OTK_ACCEPTED',\r\n  OTK_COMPLETED = 'OTK_COMPLETED',\r\n}\r\n\r\nexport interface ContactCardSharedCipherData {\r\n  // Shared read access between initiator and responder. But only the initiator has write access.\r\n  sharedCipherDataClearJson: any;\r\n}\r\n\r\n/**\r\n * The contents of the one-time key cipher\r\n */\r\nexport interface OtKeyCipherClearJson2 {\r\n  // Used to confirm to the initiator that the responder has access to the one-time key.\r\n  nonce: string;\r\n  // Data sent from initiator to the responder\r\n  initiator: {\r\n    oneTimePbk: object; // one-time public encryption key the responder will use to send data back to the initiator\r\n    pbk: object; // public encryption key\r\n    sigPbk: object; // public signing key\r\n    message?: any;\r\n    contactCard?: ContactCardSharedCipherData;\r\n  };\r\n}\r\n\r\nexport interface KeyExchangeOtkNode extends Node, TimeStamped {\r\n  state?: KeyExchangeOtkState;\r\n  sharedKey?: KeyNode;\r\n  mkSharedKey?: KeyNode;\r\n  initiatorSigPxk?: KeyNode;\r\n  responderSigPxk?: KeyNode;\r\n  initiatorOneTimePbkCipher?: string;\r\n  otKeyParams?: string;\r\n  otKeyCipher?: string;\r\n  otKeyCipherClearJson?: OtKeyCipherClearJson2;\r\n  responderPbkCipher?: string;\r\n}\r\n\r\nexport enum KeyExchangeState {\r\n  IN_PROGRESS = 'IN_PROGRESS',\r\n  COMPLETED = 'COMPLETED',\r\n  DECLINED = 'DECLINED',\r\n  CANCELLED = 'CANCELLED',\r\n  DELETED = 'DELETED',\r\n}\r\n\r\nexport enum KeyExchangeMode {\r\n  OTK = 'OTK',\r\n}\r\n\r\nexport interface KeyExchangeNode extends Node, TimeStamped {\r\n  expiryTime?: DateTime;\r\n  token?: string;\r\n  tokenExpiryTime?: DateTime;\r\n  state?: KeyExchangeState;\r\n  mode?: KeyExchangeMode;\r\n  initiator?: UserNode;\r\n  responder?: UserNode;\r\n  initiatorRootKeyCipher?: string;\r\n  responderRootKeyCipher?: string;\r\n  initiatorActionRequired?: boolean;\r\n  responderActionRequired?: boolean;\r\n  createTp?: boolean;\r\n  otk?: KeyExchangeOtkNode;\r\n  isInitiator?: boolean;\r\n  isExpired?: boolean;\r\n  responderEmailAddress?: LrEmail;\r\n}\r\n\r\nexport interface SharedItems {\r\n  directories?: Connection<DirectoryNode>;\r\n  files?: Connection<FileNode>;\r\n}\r\n\r\nexport interface SharedContactCardNode extends Node, TimeStamped {\r\n  owner?: UserNode;\r\n  receiver?: UserNode;\r\n  sharedKey?: KeyNode;\r\n  sharedCipherData?: string;\r\n  sharedCipherDataClearJson?: any;\r\n  sharedCipherDataSig?: string;\r\n  sharedCipherDataSigPxk?: KeyNode;\r\n  ownerCipherData?: string;\r\n  ownerCipherDataClearJson?: any;\r\n  ownerKey?: KeyNode;\r\n  ownerPlainData?: string;\r\n  ownerPlainDataJson?: any;\r\n  ownerPlainDataSig?: string;\r\n  receiverCipherData?: string;\r\n  receiverCipherDataClearJson?: any;\r\n  receiverKey?: KeyNode;\r\n}\r\n\r\nexport interface UserSharedKeyNode extends Node, TimeStamped {\r\n  keyExchange?: KeyExchangeNode;\r\n  user?: UserNode;\r\n  userPrk?: KeyNode;\r\n  userSigPrk?: KeyNode;\r\n  other?: UserNode;\r\n  otherPbk?: KeyNode;\r\n  otherSigPbk?: KeyNode;\r\n  sharedKey?: KeyNode;\r\n  mkSharedKey?: KeyNode;\r\n  mkPxk?: KeyNode;\r\n  mkReshareRequestCipher?: string;\r\n  mkReshareResponseCipher?: string;\r\n  mkReshareRequestCipherClearJson?: any;\r\n  mkReshareResponseCipherClearJson?: any;\r\n  mkReshareRequestSent?: boolean;\r\n  mkReshareResponseSent?: boolean;\r\n}\r\n\r\nexport interface CurrentUserSharedKeyNode extends Node, TimeStamped {\r\n  user?: UserNode;\r\n  other?: UserNode;\r\n  userSharedKey?: UserSharedKeyNode;\r\n}\r\n\r\nexport interface TpNode extends Node, TimeStamped {\r\n  user?: UserNode;\r\n  other?: UserNode;\r\n  currentUserSharedKey?: CurrentUserSharedKeyNode;\r\n  isCompleted?: boolean;\r\n  sharedKey?: KeyNode;\r\n  sharedContactCard?: SharedContactCardNode;\r\n  myContactCard?: SharedContactCardNode;\r\n  myItems?: SharedItems;\r\n  sharedItems?: SharedItems;\r\n  myScenarios?: Connection<ScenarioNode>;\r\n  sharedScenarios?: Connection<SharedScenarioNode>;\r\n}\r\n\r\nexport enum TpAssemblyState {\r\n  DISABLED = 'DISABLED',\r\n  ENABLED = 'ENABLED',\r\n  CLAIMED = 'CLAIMED',\r\n  APPROVED = 'APPROVED',\r\n  REJECTED = 'REJECTED',\r\n  EXPIRED = 'EXPIRED',\r\n  CANCELLED = 'CANCELLED',\r\n  RESET = 'RESET',\r\n}\r\n\r\nexport enum TpClaimState {\r\n  CLAIMED = 'CLAIMED',\r\n  APPROVED = 'APPROVED',\r\n  REJECTED = 'REJECTED',\r\n  EXPIRED = 'EXPIRED',\r\n  CANCELLED = 'CANCELLED',\r\n  RESET = 'RESET',\r\n}\r\n\r\nexport enum TpClaimApproverState {\r\n  CLAIMED = 'CLAIMED',\r\n  APPROVED = 'APPROVED',\r\n  REJECTED = 'REJECTED',\r\n}\r\n\r\nexport interface TpPasswordResetApproval extends Node, TimeStamped {\r\n  approverEmail?: string;\r\n  receiverCipher?: string;\r\n  receiverCipherClearJson?: any;\r\n  receiverCipherPartialAssemblyKey?: string;\r\n  receiverCipherPartialAssemblyKeyClearJson?: any;\r\n}\r\n\r\n// export interface TpPasswordResetUser {\r\n//   username?: string;\r\n//   resetUsername?: string;\r\n//   state?: TpAssemblyState;\r\n//   passKey?: PassKeyNode;\r\n//   masterKey?: KeyNode;\r\n//   pxk?: KeyNode;\r\n//   approvals?: TpPasswordResetApproval[];\r\n//   assemblyCipherData?: string;\r\n//   wrappedAssemblyKeyVerifierPrk?: string;\r\n// }\r\n\r\nexport interface TpPasswordResetUserApprovalNode extends Node, TimeStamped {\r\n  receiverCipher?: string;\r\n  receiverCipherClearJson?: any;\r\n  receiverCipherPartialAssemblyKey?: string;\r\n  receiverCipherPartialAssemblyKeyClearJson?: any;\r\n  approverEmail?: string;\r\n}\r\n\r\nexport interface TpPasswordResetUserApprover {\r\n  name?: string;\r\n  email?: string;\r\n  state?: TpClaimApproverState;\r\n}\r\n\r\nexport interface TpPasswordResetUserSubAssembly {\r\n  singleReject?: boolean;\r\n  quorum?: number;\r\n  approvers?: TpPasswordResetUserApprover[];\r\n}\r\n\r\nexport interface TpPasswordResetUserAssembly {\r\n  singleReject?: boolean;\r\n  quorum?: number;\r\n  subAssemblies?: TpPasswordResetUserSubAssembly[];\r\n}\r\n\r\nexport interface TpPasswordResetUserNode {\r\n  username?: string;\r\n  resetUsername?: string;\r\n  state?: TpClaimState;\r\n  passKey?: PassKeyNode;\r\n  masterKey?: KeyNode;\r\n  pxk?: KeyNode;\r\n  sessionEncryptionKey?: string;\r\n  approvals?: TpPasswordResetUserApprovalNode[];\r\n  assemblyCipherData?: string;\r\n  wrappedAssemblyKeyVerifierPrk?: string;\r\n  assembly?: TpPasswordResetUserAssembly;\r\n}\r\n\r\nexport interface TpPasswordResetNode extends Node, TimeStamped {\r\n  assembly?: TpAssemblyNode;\r\n  request?: TpPasswordResetRequestNode;\r\n  applied?: boolean;\r\n}\r\n\r\nexport interface TpAssemblyNode extends Node, TimeStamped {\r\n  id?: ID;\r\n  singleReject?: boolean;\r\n  quorum?: number;\r\n  subjectKey?: KeyNode;\r\n  assemblyKey?: KeyNode;\r\n  assemblyCipherData?: string;\r\n  assemblyCipherDataClearJson?: any;\r\n  subAssemblies?: Connection<TpSubAssemblyNode>;\r\n}\r\n\r\nexport interface TpSubAssemblyNode extends Node, TimeStamped {\r\n  singleReject?: boolean;\r\n  quorum?: number;\r\n  subjectCipherData?: string;\r\n  subjectCipherDataClearJson?: string;\r\n  approvers?: Connection<TpAssemblyApproverNode>;\r\n}\r\n\r\nexport interface TpAssemblyApproverNode extends Node, TimeStamped {\r\n  sharedKey?: KeyNode;\r\n  sharedCipherData?: string;\r\n  sharedCipherApprovalData?: string;\r\n  tp?: TpNode;\r\n}\r\n\r\nexport interface SharedTpPasswordResetNode extends Node, TimeStamped {\r\n  assembly?: SharedTpAssemblyNode;\r\n  tp?: TpNode;\r\n  sharedRequest?: SharedTpPasswordResetRequestNode;\r\n}\r\n\r\nexport interface SharedTpAssemblyNode extends Node, TimeStamped {\r\n  asApprovers?: Connection<TpAssemblyAsApproverNode>;\r\n}\r\n\r\nexport interface TpAssemblyAsApproverNode extends Node, TimeStamped {\r\n  sharedKey?: KeyNode;\r\n  sharedCipherData?: string;\r\n}\r\n\r\nexport interface SharedTpPasswordResetRequestNode extends Node, TimeStamped {\r\n  claim?: SharedTpClaimNode;\r\n  pxk?: KeyNode;\r\n}\r\n\r\nexport interface SharedTpClaimNode extends Node, TimeStamped {\r\n  state?: TpClaimState;\r\n  asClaimApprovers?: Connection<SharedTpClaimApproverNode>;\r\n}\r\n\r\nexport interface SharedTpClaimApproverNode extends Node, TimeStamped {\r\n  state?: TpClaimApproverState;\r\n  sharedKey?: KeyNode;\r\n  sharedCipherApprovalData?: string;\r\n  sharedCipherPartialAssemblyKey?: string;\r\n  receiverApprovals?: Connection<SharedTpClaimReceiverApprovalNode>;\r\n}\r\n\r\nexport interface SharedTpClaimReceiverApprovalNode extends Node, TimeStamped {\r\n  pxk?: KeyNode;\r\n}\r\n\r\nexport enum LockState {\r\n  UNLOCKED = 'UNLOCKED',\r\n  MUTEX_LOCKED = 'MUTEX_LOCKED',\r\n}\r\n"]}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
export function handleCognitoCallback(method) {
|
|
2
|
+
return new Promise((resolve, reject) => method((err, result) => (err ? reject(err) : resolve(result))));
|
|
3
|
+
}
|
|
4
|
+
export const awsFetch = (authUrl) => {
|
|
5
|
+
const fetch = window.fetch;
|
|
6
|
+
return (url, options) => {
|
|
7
|
+
const pass = () => fetch(url, options);
|
|
8
|
+
if (!options || !options.headers || !options.headers['X-Amz-Target']) {
|
|
9
|
+
return pass();
|
|
10
|
+
}
|
|
11
|
+
const operation = options.headers['X-Amz-Target'].split('.');
|
|
12
|
+
if (operation.length < 2 ||
|
|
13
|
+
operation[0] !== 'AWSCognitoIdentityProviderService') {
|
|
14
|
+
return pass();
|
|
15
|
+
}
|
|
16
|
+
const body = JSON.parse(options.body);
|
|
17
|
+
if (body && body.ClientMetadata && body.ClientMetadata.noProxy === 'true') {
|
|
18
|
+
return pass();
|
|
19
|
+
}
|
|
20
|
+
let custom = false;
|
|
21
|
+
if (operation[1] === 'RespondToAuthChallenge') {
|
|
22
|
+
if (body && body.ChallengeName === 'NEW_PASSWORD_REQUIRED') {
|
|
23
|
+
return pass();
|
|
24
|
+
}
|
|
25
|
+
custom = true;
|
|
26
|
+
}
|
|
27
|
+
else if (operation[1] === 'InitiateAuth') {
|
|
28
|
+
if (body.AuthFlow === 'REFRESH_TOKEN_AUTH') {
|
|
29
|
+
custom = true;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
if (!custom) {
|
|
33
|
+
return pass();
|
|
34
|
+
}
|
|
35
|
+
return fetch(`${authUrl}auth/proxy/`, Object.assign(Object.assign({}, options), { credentials: 'include' }));
|
|
36
|
+
};
|
|
37
|
+
};
|
|
38
|
+
export const configureAmplifyAuth = ({ authUrl: authUrl, userPoolId, userPoolWebClientId }, auth) => {
|
|
39
|
+
return () => {
|
|
40
|
+
const tokens = userPoolId.split('_');
|
|
41
|
+
if (tokens.length < 2) {
|
|
42
|
+
throw new Error('userPoolId should have this format: {aws-region}_xxxxx');
|
|
43
|
+
}
|
|
44
|
+
window.fetch = awsFetch(authUrl);
|
|
45
|
+
auth.configure({
|
|
46
|
+
// REQUIRED - Amazon Cognito Region
|
|
47
|
+
region: tokens[0],
|
|
48
|
+
// OPTIONAL - Amazon Cognito User Pool ID
|
|
49
|
+
userPoolId,
|
|
50
|
+
// OPTIONAL - Amazon Cognito Web Client ID (26-char alphanumeric string)
|
|
51
|
+
userPoolWebClientId,
|
|
52
|
+
// OPTIONAL - Enforce user authentication prior to accessing AWS resources or not
|
|
53
|
+
mandatorySignIn: false,
|
|
54
|
+
});
|
|
55
|
+
};
|
|
56
|
+
};
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC5jb25maWcuanMiLCJzb3VyY2VSb290IjoiQzovUHJvamVjdHMvdGVzdC9wcm9qZWN0cy9jb3JlL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9hdXRoL2F1dGguY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUdBLE1BQU0sVUFBVSxxQkFBcUIsQ0FDbkMsTUFBNkQ7SUFFN0QsT0FBTyxJQUFJLE9BQU8sQ0FBSSxDQUFDLE9BQU8sRUFBRSxNQUFNLEVBQUUsRUFBRSxDQUN4QyxNQUFNLENBQUMsQ0FBQyxHQUFHLEVBQUUsTUFBTSxFQUFFLEVBQUUsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUMvRCxDQUFDO0FBQ0osQ0FBQztBQUVELE1BQU0sQ0FBQyxNQUFNLFFBQVEsR0FBRyxDQUFDLE9BQWUsRUFBRSxFQUFFO0lBQzFDLE1BQU0sS0FBSyxHQUFHLE1BQU0sQ0FBQyxLQUFLLENBQUM7SUFFM0IsT0FBTyxDQUFDLEdBQUcsRUFBRSxPQUFPLEVBQUUsRUFBRTtRQUN0QixNQUFNLElBQUksR0FBRyxHQUFHLEVBQUUsQ0FBQyxLQUFLLENBQUMsR0FBRyxFQUFFLE9BQU8sQ0FBQyxDQUFDO1FBRXZDLElBQUksQ0FBQyxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxjQUFjLENBQUMsRUFBRTtZQUNwRSxPQUFPLElBQUksRUFBRSxDQUFDO1NBQ2Y7UUFFRCxNQUFNLFNBQVMsR0FBRyxPQUFPLENBQUMsT0FBTyxDQUFDLGNBQWMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUM3RCxJQUNFLFNBQVMsQ0FBQyxNQUFNLEdBQUcsQ0FBQztZQUNwQixTQUFTLENBQUMsQ0FBQyxDQUFDLEtBQUssbUNBQW1DLEVBQ3BEO1lBQ0EsT0FBTyxJQUFJLEVBQUUsQ0FBQztTQUNmO1FBRUQsTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUM7UUFFdEMsSUFBSSxJQUFJLElBQUksSUFBSSxDQUFDLGNBQWMsSUFBSSxJQUFJLENBQUMsY0FBYyxDQUFDLE9BQU8sS0FBSyxNQUFNLEVBQUU7WUFDekUsT0FBTyxJQUFJLEVBQUUsQ0FBQztTQUNmO1FBRUQsSUFBSSxNQUFNLEdBQUcsS0FBSyxDQUFDO1FBRW5CLElBQUksU0FBUyxDQUFDLENBQUMsQ0FBQyxLQUFLLHdCQUF3QixFQUFFO1lBQzdDLElBQUksSUFBSSxJQUFJLElBQUksQ0FBQyxhQUFhLEtBQUssdUJBQXVCLEVBQUU7Z0JBQzFELE9BQU8sSUFBSSxFQUFFLENBQUM7YUFDZjtZQUNELE1BQU0sR0FBRyxJQUFJLENBQUM7U0FDZjthQUFNLElBQUksU0FBUyxDQUFDLENBQUMsQ0FBQyxLQUFLLGNBQWMsRUFBRTtZQUMxQyxJQUFJLElBQUksQ0FBQyxRQUFRLEtBQUssb0JBQW9CLEVBQUU7Z0JBQzFDLE1BQU0sR0FBRyxJQUFJLENBQUM7YUFDZjtTQUNGO1FBRUQsSUFBSSxDQUFDLE1BQU0sRUFBRTtZQUNYLE9BQU8sSUFBSSxFQUFFLENBQUM7U0FDZjtRQUVELE9BQU8sS0FBSyxDQUFDLEdBQUcsT0FBTyxhQUFhLGtDQUMvQixPQUFPLEtBQ1YsV0FBVyxFQUFFLFNBQVMsSUFDdEIsQ0FBQztJQUNMLENBQUMsQ0FBQztBQUNKLENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLG9CQUFvQixHQUFHLENBQ2xDLEVBQUUsT0FBTyxFQUFFLE9BQU8sRUFBRSxVQUFVLEVBQUUsbUJBQW1CLEVBQW1CLEVBQ3RFLElBQWUsRUFDZixFQUFFO0lBQ0YsT0FBTyxHQUFHLEVBQUU7UUFDVixNQUFNLE1BQU0sR0FBRyxVQUFVLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ3JDLElBQUksTUFBTSxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUU7WUFDckIsTUFBTSxJQUFJLEtBQUssQ0FBQyx3REFBd0QsQ0FBQyxDQUFDO1NBQzNFO1FBRUQsTUFBTSxDQUFDLEtBQUssR0FBRyxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUM7UUFFakMsSUFBSSxDQUFDLFNBQVMsQ0FBQztZQUNiLG1DQUFtQztZQUNuQyxNQUFNLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQztZQUNqQix5Q0FBeUM7WUFDekMsVUFBVTtZQUNWLHdFQUF3RTtZQUN4RSxtQkFBbUI7WUFDbkIsaUZBQWlGO1lBQ2pGLGVBQWUsRUFBRSxLQUFLO1NBQ3ZCLENBQUMsQ0FBQztJQUNMLENBQUMsQ0FBQztBQUNKLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEF1dGhDbGFzcyB9IGZyb20gJ0Bhd3MtYW1wbGlmeS9hdXRoL2xpYi1lc20vQXV0aCc7XHJcbmltcG9ydCB7IExpZmVSZWFkeUNvbmZpZyB9IGZyb20gJy4uL2xpZmUtcmVhZHkuY29uZmlnJztcclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBoYW5kbGVDb2duaXRvQ2FsbGJhY2s8VD4oXHJcbiAgbWV0aG9kOiAoY2FsbGJhY2s6IChlcnI/OiBFcnJvciwgcmVzdWx0PzogVCkgPT4gdm9pZCkgPT4gdm9pZFxyXG4pOiBQcm9taXNlPFQ+IHtcclxuICByZXR1cm4gbmV3IFByb21pc2U8VD4oKHJlc29sdmUsIHJlamVjdCkgPT5cclxuICAgIG1ldGhvZCgoZXJyLCByZXN1bHQpID0+IChlcnIgPyByZWplY3QoZXJyKSA6IHJlc29sdmUocmVzdWx0KSkpXHJcbiAgKTtcclxufVxyXG5cclxuZXhwb3J0IGNvbnN0IGF3c0ZldGNoID0gKGF1dGhVcmw6IHN0cmluZykgPT4ge1xyXG4gIGNvbnN0IGZldGNoID0gd2luZG93LmZldGNoO1xyXG5cclxuICByZXR1cm4gKHVybCwgb3B0aW9ucykgPT4ge1xyXG4gICAgY29uc3QgcGFzcyA9ICgpID0+IGZldGNoKHVybCwgb3B0aW9ucyk7XHJcblxyXG4gICAgaWYgKCFvcHRpb25zIHx8ICFvcHRpb25zLmhlYWRlcnMgfHwgIW9wdGlvbnMuaGVhZGVyc1snWC1BbXotVGFyZ2V0J10pIHtcclxuICAgICAgcmV0dXJuIHBhc3MoKTtcclxuICAgIH1cclxuXHJcbiAgICBjb25zdCBvcGVyYXRpb24gPSBvcHRpb25zLmhlYWRlcnNbJ1gtQW16LVRhcmdldCddLnNwbGl0KCcuJyk7XHJcbiAgICBpZiAoXHJcbiAgICAgIG9wZXJhdGlvbi5sZW5ndGggPCAyIHx8XHJcbiAgICAgIG9wZXJhdGlvblswXSAhPT0gJ0FXU0NvZ25pdG9JZGVudGl0eVByb3ZpZGVyU2VydmljZSdcclxuICAgICkge1xyXG4gICAgICByZXR1cm4gcGFzcygpO1xyXG4gICAgfVxyXG5cclxuICAgIGNvbnN0IGJvZHkgPSBKU09OLnBhcnNlKG9wdGlvbnMuYm9keSk7XHJcblxyXG4gICAgaWYgKGJvZHkgJiYgYm9keS5DbGllbnRNZXRhZGF0YSAmJiBib2R5LkNsaWVudE1ldGFkYXRhLm5vUHJveHkgPT09ICd0cnVlJykge1xyXG4gICAgICByZXR1cm4gcGFzcygpO1xyXG4gICAgfVxyXG5cclxuICAgIGxldCBjdXN0b20gPSBmYWxzZTtcclxuXHJcbiAgICBpZiAob3BlcmF0aW9uWzFdID09PSAnUmVzcG9uZFRvQXV0aENoYWxsZW5nZScpIHtcclxuICAgICAgaWYgKGJvZHkgJiYgYm9keS5DaGFsbGVuZ2VOYW1lID09PSAnTkVXX1BBU1NXT1JEX1JFUVVJUkVEJykge1xyXG4gICAgICAgIHJldHVybiBwYXNzKCk7XHJcbiAgICAgIH1cclxuICAgICAgY3VzdG9tID0gdHJ1ZTtcclxuICAgIH0gZWxzZSBpZiAob3BlcmF0aW9uWzFdID09PSAnSW5pdGlhdGVBdXRoJykge1xyXG4gICAgICBpZiAoYm9keS5BdXRoRmxvdyA9PT0gJ1JFRlJFU0hfVE9LRU5fQVVUSCcpIHtcclxuICAgICAgICBjdXN0b20gPSB0cnVlO1xyXG4gICAgICB9XHJcbiAgICB9XHJcblxyXG4gICAgaWYgKCFjdXN0b20pIHtcclxuICAgICAgcmV0dXJuIHBhc3MoKTtcclxuICAgIH1cclxuXHJcbiAgICByZXR1cm4gZmV0Y2goYCR7YXV0aFVybH1hdXRoL3Byb3h5L2AsIHtcclxuICAgICAgLi4ub3B0aW9ucyxcclxuICAgICAgY3JlZGVudGlhbHM6ICdpbmNsdWRlJyxcclxuICAgIH0pO1xyXG4gIH07XHJcbn07XHJcblxyXG5leHBvcnQgY29uc3QgY29uZmlndXJlQW1wbGlmeUF1dGggPSAoXHJcbiAgeyBhdXRoVXJsOiBhdXRoVXJsLCB1c2VyUG9vbElkLCB1c2VyUG9vbFdlYkNsaWVudElkIH06IExpZmVSZWFkeUNvbmZpZyxcclxuICBhdXRoOiBBdXRoQ2xhc3NcclxuKSA9PiB7XHJcbiAgcmV0dXJuICgpID0+IHtcclxuICAgIGNvbnN0IHRva2VucyA9IHVzZXJQb29sSWQuc3BsaXQoJ18nKTtcclxuICAgIGlmICh0b2tlbnMubGVuZ3RoIDwgMikge1xyXG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ3VzZXJQb29sSWQgc2hvdWxkIGhhdmUgdGhpcyBmb3JtYXQ6IHthd3MtcmVnaW9ufV94eHh4eCcpO1xyXG4gICAgfVxyXG5cclxuICAgIHdpbmRvdy5mZXRjaCA9IGF3c0ZldGNoKGF1dGhVcmwpO1xyXG5cclxuICAgIGF1dGguY29uZmlndXJlKHtcclxuICAgICAgLy8gUkVRVUlSRUQgLSBBbWF6b24gQ29nbml0byBSZWdpb25cclxuICAgICAgcmVnaW9uOiB0b2tlbnNbMF0sXHJcbiAgICAgIC8vIE9QVElPTkFMIC0gQW1hem9uIENvZ25pdG8gVXNlciBQb29sIElEXHJcbiAgICAgIHVzZXJQb29sSWQsXHJcbiAgICAgIC8vIE9QVElPTkFMIC0gQW1hem9uIENvZ25pdG8gV2ViIENsaWVudCBJRCAoMjYtY2hhciBhbHBoYW51bWVyaWMgc3RyaW5nKVxyXG4gICAgICB1c2VyUG9vbFdlYkNsaWVudElkLFxyXG4gICAgICAvLyBPUFRJT05BTCAtIEVuZm9yY2UgdXNlciBhdXRoZW50aWNhdGlvbiBwcmlvciB0byBhY2Nlc3NpbmcgQVdTIHJlc291cmNlcyBvciBub3RcclxuICAgICAgbWFuZGF0b3J5U2lnbkluOiBmYWxzZSxcclxuICAgIH0pO1xyXG4gIH07XHJcbn07XHJcbiJdfQ==
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import gql from 'graphql-tag';
|
|
2
|
+
import { gqlTyped } from '../_common/ast';
|
|
3
|
+
export const PasswordChangeRequestMutation = gql `
|
|
4
|
+
mutation {
|
|
5
|
+
passwordChangeRequest(input: {}) {
|
|
6
|
+
challenge
|
|
7
|
+
passKeys {
|
|
8
|
+
id
|
|
9
|
+
passIdpParams
|
|
10
|
+
wrappedPassIdpVerifierPrk
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
`;
|
|
15
|
+
export const PasswordChangeMutation = gql `
|
|
16
|
+
mutation PasswordChange($input: PasswordChangeInput!) {
|
|
17
|
+
passwordChange(input: $input) {
|
|
18
|
+
token
|
|
19
|
+
newPassKey {
|
|
20
|
+
id
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
`;
|
|
25
|
+
export const PasswordChangeConfigQuery = gql `
|
|
26
|
+
query PasswordChangeConfigQuery {
|
|
27
|
+
passwordChangeConfig {
|
|
28
|
+
maxAuthAgeSeconds
|
|
29
|
+
authTime
|
|
30
|
+
serverTime
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
`;
|
|
34
|
+
export const SetSessionEncryptionKeyMutation = gqlTyped `
|
|
35
|
+
mutation SetSessionEncryptionKeyMutation($input: SetSessionEncryptionKeyInput!) {
|
|
36
|
+
setSessionEncryptionKey(input: $input) {
|
|
37
|
+
sessionEncryptionKey
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
`;
|
|
41
|
+
export const ClearSessionEncryptionKeyMutation = gqlTyped `
|
|
42
|
+
mutation ClearSessionEncryptionKeyMutation {
|
|
43
|
+
clearSessionEncryptionKey(input: {}) {
|
|
44
|
+
sessionEncryptionKey
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
`;
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC5ncWwuanMiLCJzb3VyY2VSb290IjoiQzovUHJvamVjdHMvdGVzdC9wcm9qZWN0cy9jb3JlL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9hdXRoL2F1dGguZ3FsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sR0FBRyxNQUFNLGFBQWEsQ0FBQztBQUM5QixPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFMUMsTUFBTSxDQUFDLE1BQU0sNkJBQTZCLEdBQUcsR0FBRyxDQUFBOzs7Ozs7Ozs7OztDQVcvQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sc0JBQXNCLEdBQUcsR0FBRyxDQUFBOzs7Ozs7Ozs7Q0FTeEMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLHlCQUF5QixHQUFHLEdBQUcsQ0FBQTs7Ozs7Ozs7Q0FRM0MsQ0FBQztBQU9GLE1BQU0sQ0FBQyxNQUFNLCtCQUErQixHQUFHLFFBQVEsQ0FBaUM7Ozs7OztDQU12RixDQUFDO0FBT0YsTUFBTSxDQUFDLE1BQU0saUNBQWlDLEdBQUcsUUFBUSxDQUFtQzs7Ozs7O0NBTTNGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgZ3FsIGZyb20gJ2dyYXBocWwtdGFnJztcclxuaW1wb3J0IHsgZ3FsVHlwZWQgfSBmcm9tICcuLi9fY29tbW9uL2FzdCc7XHJcblxyXG5leHBvcnQgY29uc3QgUGFzc3dvcmRDaGFuZ2VSZXF1ZXN0TXV0YXRpb24gPSBncWxgXHJcbiAgbXV0YXRpb24ge1xyXG4gICAgcGFzc3dvcmRDaGFuZ2VSZXF1ZXN0KGlucHV0OiB7fSkge1xyXG4gICAgICBjaGFsbGVuZ2VcclxuICAgICAgcGFzc0tleXMge1xyXG4gICAgICAgIGlkXHJcbiAgICAgICAgcGFzc0lkcFBhcmFtc1xyXG4gICAgICAgIHdyYXBwZWRQYXNzSWRwVmVyaWZpZXJQcmtcclxuICAgICAgfVxyXG4gICAgfVxyXG4gIH1cclxuYDtcclxuXHJcbmV4cG9ydCBjb25zdCBQYXNzd29yZENoYW5nZU11dGF0aW9uID0gZ3FsYFxyXG4gIG11dGF0aW9uIFBhc3N3b3JkQ2hhbmdlKCRpbnB1dDogUGFzc3dvcmRDaGFuZ2VJbnB1dCEpIHtcclxuICAgIHBhc3N3b3JkQ2hhbmdlKGlucHV0OiAkaW5wdXQpIHtcclxuICAgICAgdG9rZW5cclxuICAgICAgbmV3UGFzc0tleSB7XHJcbiAgICAgICAgaWRcclxuICAgICAgfVxyXG4gICAgfVxyXG4gIH1cclxuYDtcclxuXHJcbmV4cG9ydCBjb25zdCBQYXNzd29yZENoYW5nZUNvbmZpZ1F1ZXJ5ID0gZ3FsYFxyXG4gIHF1ZXJ5IFBhc3N3b3JkQ2hhbmdlQ29uZmlnUXVlcnkge1xyXG4gICAgcGFzc3dvcmRDaGFuZ2VDb25maWcge1xyXG4gICAgICBtYXhBdXRoQWdlU2Vjb25kc1xyXG4gICAgICBhdXRoVGltZVxyXG4gICAgICBzZXJ2ZXJUaW1lXHJcbiAgICB9XHJcbiAgfVxyXG5gO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBTZXRTZXNzaW9uRW5jcnlwdGlvbktleU11dGF0aW9uIHtcclxuICBzZXRTZXNzaW9uRW5jcnlwdGlvbktleToge1xyXG4gICAgc2Vzc2lvbkVuY3J5cHRpb25LZXk6IHN0cmluZztcclxuICB9O1xyXG59XHJcbmV4cG9ydCBjb25zdCBTZXRTZXNzaW9uRW5jcnlwdGlvbktleU11dGF0aW9uID0gZ3FsVHlwZWQ8U2V0U2Vzc2lvbkVuY3J5cHRpb25LZXlNdXRhdGlvbj5gXHJcbm11dGF0aW9uIFNldFNlc3Npb25FbmNyeXB0aW9uS2V5TXV0YXRpb24oJGlucHV0OiBTZXRTZXNzaW9uRW5jcnlwdGlvbktleUlucHV0ISkge1xyXG4gIHNldFNlc3Npb25FbmNyeXB0aW9uS2V5KGlucHV0OiAkaW5wdXQpIHtcclxuICAgIHNlc3Npb25FbmNyeXB0aW9uS2V5XHJcbiAgfVxyXG59XHJcbmA7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIENsZWFyU2Vzc2lvbkVuY3J5cHRpb25LZXlNdXRhdGlvbiB7XHJcbiAgY2xlYXJTZXNzaW9uRW5jcnlwdGlvbktleToge1xyXG4gICAgc2Vzc2lvbkVuY3J5cHRpb25LZXk6IHN0cmluZztcclxuICB9O1xyXG59XHJcbmV4cG9ydCBjb25zdCBDbGVhclNlc3Npb25FbmNyeXB0aW9uS2V5TXV0YXRpb24gPSBncWxUeXBlZDxDbGVhclNlc3Npb25FbmNyeXB0aW9uS2V5TXV0YXRpb24+YFxyXG5tdXRhdGlvbiBDbGVhclNlc3Npb25FbmNyeXB0aW9uS2V5TXV0YXRpb24ge1xyXG4gIGNsZWFyU2Vzc2lvbkVuY3J5cHRpb25LZXkoaW5wdXQ6IHt9KSB7XHJcbiAgICBzZXNzaW9uRW5jcnlwdGlvbktleVxyXG4gIH1cclxufVxyXG5gO1xyXG4iXX0=
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { CognitoUser } from '@aws-amplify/auth';
|
|
2
|
+
export class CognitoChallengeUser extends CognitoUser {
|
|
3
|
+
constructor() {
|
|
4
|
+
super(...arguments);
|
|
5
|
+
this.isTpPasswordResetUser = false;
|
|
6
|
+
}
|
|
7
|
+
}
|
|
8
|
+
export var FeatureAction;
|
|
9
|
+
(function (FeatureAction) {
|
|
10
|
+
// Just the one for now
|
|
11
|
+
FeatureAction["ACCESS"] = "access";
|
|
12
|
+
})(FeatureAction || (FeatureAction = {}));
|
|
13
|
+
export class Features {
|
|
14
|
+
}
|
|
15
|
+
export class CurrentUser {
|
|
16
|
+
}
|
|
17
|
+
export class LoginResult {
|
|
18
|
+
}
|
|
19
|
+
export class RegisterResult {
|
|
20
|
+
}
|
|
21
|
+
export var RecoveryStatus;
|
|
22
|
+
(function (RecoveryStatus) {
|
|
23
|
+
RecoveryStatus["NONE"] = "none";
|
|
24
|
+
RecoveryStatus["NEW_PASSWORD"] = "new-password";
|
|
25
|
+
RecoveryStatus["OLD_PASSWORD"] = "old-password";
|
|
26
|
+
})(RecoveryStatus || (RecoveryStatus = {}));
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiJDOi9Qcm9qZWN0cy90ZXN0L3Byb2plY3RzL2NvcmUvc3JjLyIsInNvdXJjZXMiOlsibGliL2F1dGgvYXV0aC50eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFvQmhELE1BQU0sT0FBTyxvQkFBcUIsU0FBUSxXQUFXO0lBQXJEOztRQUlFLDBCQUFxQixHQUFHLEtBQUssQ0FBQztJQUNoQyxDQUFDO0NBQUE7QUFFRCxNQUFNLENBQU4sSUFBWSxhQUdYO0FBSEQsV0FBWSxhQUFhO0lBQ3ZCLHVCQUF1QjtJQUN2QixrQ0FBaUIsQ0FBQTtBQUNuQixDQUFDLEVBSFcsYUFBYSxLQUFiLGFBQWEsUUFHeEI7QUFFRCxNQUFNLE9BQU8sUUFBUTtDQUlwQjtBQUVELE1BQU0sT0FBTyxXQUFXO0NBZ0J2QjtBQU1ELE1BQU0sT0FBTyxXQUFXO0NBS3ZCO0FBRUQsTUFBTSxPQUFPLGNBQWM7Q0FLMUI7QUFFRCxNQUFNLENBQU4sSUFBWSxjQUlYO0FBSkQsV0FBWSxjQUFjO0lBQ3hCLCtCQUFhLENBQUE7SUFDYiwrQ0FBNkIsQ0FBQTtJQUM3QiwrQ0FBNkIsQ0FBQTtBQUMvQixDQUFDLEVBSlcsY0FBYyxLQUFkLGNBQWMsUUFJekIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb2duaXRvVXNlciB9IGZyb20gJ0Bhd3MtYW1wbGlmeS9hdXRoJztcclxuaW1wb3J0IHsgSldLIH0gZnJvbSAnbm9kZS1qb3NlJztcclxuaW1wb3J0IHsgVHBQYXNzd29yZFJlc2V0VXNlck5vZGUgfSBmcm9tICcuLi9hcGkvdHlwZXMnO1xyXG5pbXBvcnQge1xyXG4gIFBhc3NJZHBQYXJhbXMsXHJcbiAgUGFzc0tleVBhcmFtcyxcclxufSBmcm9tICcuLi9jcnlwdG9ncmFwaHkvY3J5cHRvZ3JhcGh5LnR5cGVzJztcclxuaW1wb3J0IHsgVXNlclBsYW4gfSBmcm9tICcuLi9wbGFuL3BsYW4udHlwZXMnO1xyXG5pbXBvcnQgeyBDdXJyZW50VXNlcktleSwgTWFpbkNvbnRhY3RDYXJkIH0gZnJvbSAnLi4vdXNlcnMvcHJvZmlsZS50eXBlcyc7XHJcbmltcG9ydCB7IFVzZXJEZWxldGUgfSBmcm9tICcuLi91c2Vycy91c2VyLnR5cGVzJztcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgUGFzc0tleUJ1bmRsZSB7XHJcbiAgcGFzc0tleVBhcmFtczogUGFzc0tleVBhcmFtcztcclxuICBwYXNzS2V5OiBKV0suS2V5O1xyXG4gIHBhc3NJZHBQYXJhbXM6IFBhc3NJZHBQYXJhbXM7XHJcbiAgcGFzc0lkcDogSldLLktleTtcclxuICBwYXNzSWRwVmVyaWZpZXI6IEpXSy5LZXk7XHJcbiAgd3JhcHBlZFBhc3NJZHBWZXJpZmllclByazogb2JqZWN0O1xyXG59XHJcblxyXG5leHBvcnQgY2xhc3MgQ29nbml0b0NoYWxsZW5nZVVzZXIgZXh0ZW5kcyBDb2duaXRvVXNlciB7XHJcbiAgcmVjb3ZlcnlTdGF0dXM6IFJlY292ZXJ5U3RhdHVzO1xyXG4gIGNoYWxsZW5nZU5hbWU6ICdTTVNfTUZBJyB8ICdTT0ZUV0FSRV9UT0tFTl9NRkEnO1xyXG4gIGNoYWxsZW5nZVBhcmFtOiBhbnk7XHJcbiAgaXNUcFBhc3N3b3JkUmVzZXRVc2VyID0gZmFsc2U7XHJcbn1cclxuXHJcbmV4cG9ydCBlbnVtIEZlYXR1cmVBY3Rpb24ge1xyXG4gIC8vIEp1c3QgdGhlIG9uZSBmb3Igbm93XHJcbiAgQUNDRVNTID0gJ2FjY2VzcycsXHJcbn1cclxuXHJcbmV4cG9ydCBjbGFzcyBGZWF0dXJlcyB7XHJcbiAgbXlWYXVsdDogRmVhdHVyZUFjdGlvbltdO1xyXG4gIHRwVmF1bHQ6IEZlYXR1cmVBY3Rpb25bXTtcclxuICBzaGFyZVZhdWx0OiBGZWF0dXJlQWN0aW9uW107XHJcbn1cclxuXHJcbmV4cG9ydCBjbGFzcyBDdXJyZW50VXNlciB7XHJcbiAgaWQ6IHN0cmluZztcclxuICBzdWI6IHN0cmluZztcclxuICB1c2VybmFtZTogc3RyaW5nO1xyXG4gIGN1cnJlbnRVc2VyS2V5OiBDdXJyZW50VXNlcktleTtcclxuICBlbWFpbDogc3RyaW5nO1xyXG4gIGVtYWlsVmVyaWZpZWQ6IGJvb2xlYW47XHJcbiAgcGhvbmU6IHN0cmluZztcclxuICBwaG9uZVZlcmlmaWVkOiBib29sZWFuO1xyXG4gIGdldEFjY2Vzc0p3dFRva2VuOiAoKSA9PiBzdHJpbmc7XHJcbiAgY29udGFjdENhcmQ6IE1haW5Db250YWN0Q2FyZDtcclxuICB1c2VyRGVsZXRlPzogVXNlckRlbGV0ZTtcclxuICB1c2VyUGxhbnM6IFVzZXJQbGFuW107XHJcbiAgZmVhdHVyZXM6IEZlYXR1cmVzO1xyXG4gIGhhc1RQVmF1bHRBY2Nlc3M6IGJvb2xlYW47XHJcbiAgc2Vzc2lvbkVuY3J5cHRpb25LZXk6IHN0cmluZztcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBUcFBhc3N3b3JkUmVzZXRVc2VyIGV4dGVuZHMgVHBQYXNzd29yZFJlc2V0VXNlck5vZGUge1xyXG4gIHN1Yjogc3RyaW5nO1xyXG59XHJcblxyXG5leHBvcnQgY2xhc3MgTG9naW5SZXN1bHQge1xyXG4gIGhhc0NoYWxsZW5nZTogYm9vbGVhbjtcclxuICBjaGFsbGVuZ2U/OiBDb2duaXRvQ2hhbGxlbmdlVXNlcjtcclxuICB1c2VyPzogQ3VycmVudFVzZXI7XHJcbiAgcmVzZXRVc2VyPzogVHBQYXNzd29yZFJlc2V0VXNlck5vZGU7XHJcbn1cclxuXHJcbmV4cG9ydCBjbGFzcyBSZWdpc3RlclJlc3VsdCB7XHJcbiAgdXNlcm5hbWU6IHN0cmluZztcclxuICB1c2VySWQ6IHN0cmluZztcclxuICBwcmVTaWduVXBUb2tlbjogc3RyaW5nO1xyXG4gIHVzZXJTdWI6IHN0cmluZztcclxufVxyXG5cclxuZXhwb3J0IGVudW0gUmVjb3ZlcnlTdGF0dXMge1xyXG4gIE5PTkUgPSAnbm9uZScsXHJcbiAgTkVXX1BBU1NXT1JEID0gJ25ldy1wYXNzd29yZCcsXHJcbiAgT0xEX1BBU1NXT1JEID0gJ29sZC1wYXNzd29yZCcsXHJcbn1cclxuIl19
|