@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,266 @@
|
|
|
1
|
+
import { __awaiter, __decorate } from "tslib";
|
|
2
|
+
import { Hub } from '@aws-amplify/core';
|
|
3
|
+
import { Inject, Injectable, Injector, NgZone } from '@angular/core';
|
|
4
|
+
import { EncryptionService } from '../cryptography/encryption.service';
|
|
5
|
+
import { KeyGraphService } from '../cryptography/key-graph.service';
|
|
6
|
+
import { LR_CONFIG } from '../life-ready.config';
|
|
7
|
+
import * as slip from '../cryptography/slip39.service';
|
|
8
|
+
import { JWK } from 'node-jose';
|
|
9
|
+
import { LrBadStateException, LrException } from '../_common/exceptions';
|
|
10
|
+
import { CompleteTpPasswordResetRequestMutation, CreateTpAssemblyKeyChallengeMutation, PreCompleteTpPasswordResetRequestMutation, } from './tp-password-reset.gql';
|
|
11
|
+
import { PasswordService } from '../auth/password.service';
|
|
12
|
+
import { HttpClient } from '@angular/common/http';
|
|
13
|
+
import { AuthClass } from '@aws-amplify/auth/lib-esm/Auth';
|
|
14
|
+
import { TpPasswordResetService, } from './tp-password-reset.service';
|
|
15
|
+
import { LifeReadyAuthService } from '../auth/life-ready-auth.service';
|
|
16
|
+
import { KeyFactoryService } from '../cryptography/key-factory.service';
|
|
17
|
+
import { TpClaimState } from '../api/types';
|
|
18
|
+
import { LrMutation, LrService } from '../api/lr-graphql';
|
|
19
|
+
import { RunOutsideAngular } from '../_common/run-outside-angular';
|
|
20
|
+
import * as i0 from "@angular/core";
|
|
21
|
+
import * as i1 from "../life-ready.config";
|
|
22
|
+
import * as i2 from "../cryptography/key-factory.service";
|
|
23
|
+
import * as i3 from "../cryptography/encryption.service";
|
|
24
|
+
import * as i4 from "../cryptography/key-graph.service";
|
|
25
|
+
import * as i5 from "../cryptography/slip39.service";
|
|
26
|
+
import * as i6 from "../auth/password.service";
|
|
27
|
+
import * as i7 from "@angular/common/http";
|
|
28
|
+
import * as i8 from "@aws-amplify/auth/lib-esm/Auth";
|
|
29
|
+
import * as i9 from "../auth/life-ready-auth.service";
|
|
30
|
+
let TpPasswordResetUserService = class TpPasswordResetUserService extends LrService {
|
|
31
|
+
constructor(ngZone, injector, config, keyFactory, encryptionService, keyGraphService, slip39Service, passwordService, http, auth, lrAuth) {
|
|
32
|
+
super(injector);
|
|
33
|
+
this.ngZone = ngZone;
|
|
34
|
+
this.injector = injector;
|
|
35
|
+
this.config = config;
|
|
36
|
+
this.keyFactory = keyFactory;
|
|
37
|
+
this.encryptionService = encryptionService;
|
|
38
|
+
this.keyGraphService = keyGraphService;
|
|
39
|
+
this.slip39Service = slip39Service;
|
|
40
|
+
this.passwordService = passwordService;
|
|
41
|
+
this.http = http;
|
|
42
|
+
this.auth = auth;
|
|
43
|
+
this.lrAuth = lrAuth;
|
|
44
|
+
this.CLIENT_NONCE_LENGTH = 32;
|
|
45
|
+
}
|
|
46
|
+
verifyEmailContact(email) {
|
|
47
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
48
|
+
const params = {
|
|
49
|
+
email,
|
|
50
|
+
};
|
|
51
|
+
return this.http
|
|
52
|
+
.post(`${this.config.authUrl}tp/password-reset/verify-contact/`, params)
|
|
53
|
+
.toPromise();
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
verifyContactRespond(claimId, claimCode) {
|
|
57
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
58
|
+
const { token } = yield this.http
|
|
59
|
+
.post(`${this.config.authUrl}cove/respond/`, {
|
|
60
|
+
claim_id: claimId,
|
|
61
|
+
v_code: claimCode,
|
|
62
|
+
})
|
|
63
|
+
.toPromise();
|
|
64
|
+
return token;
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
requestReset(password, claimId, claimToken) {
|
|
68
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
69
|
+
// Generate the key materials
|
|
70
|
+
const passKeyBundle = yield this.passwordService.createPassKeyBundle(password);
|
|
71
|
+
const masterKey = yield this.keyFactory.createKey();
|
|
72
|
+
const wrappedMasterKey = yield this.encryptionService.encrypt(passKeyBundle.passKey, masterKey.toJSON(true));
|
|
73
|
+
// Ephemeral PKC key
|
|
74
|
+
const prk = yield this.keyFactory.createPkcKey();
|
|
75
|
+
const masterKeyWrappedPrk = yield this.encryptionService.encrypt(masterKey, prk.toJSON(true));
|
|
76
|
+
// API call to setup reset request
|
|
77
|
+
const requestResetResult = yield this.http
|
|
78
|
+
.post(`${this.config.authUrl}tp/password-reset/request/`, {
|
|
79
|
+
claimId,
|
|
80
|
+
claimToken,
|
|
81
|
+
pass_key_params: passKeyBundle.passKeyParams,
|
|
82
|
+
pass_idp_params: passKeyBundle.passIdpParams,
|
|
83
|
+
pass_idp_verifier_pbk: passKeyBundle.passIdpVerifier.toJSON(),
|
|
84
|
+
wrapped_pass_idp_verifier_prk: passKeyBundle.wrappedPassIdpVerifierPrk,
|
|
85
|
+
wrapped_master_key: wrappedMasterKey,
|
|
86
|
+
pbk: prk.toJSON(),
|
|
87
|
+
master_key_wrapped_prk: masterKeyWrappedPrk,
|
|
88
|
+
})
|
|
89
|
+
.toPromise();
|
|
90
|
+
console.log(requestResetResult);
|
|
91
|
+
console.log('Using new password: ', this.passwordService.getPassIdpString(passKeyBundle.passIdp));
|
|
92
|
+
// API call to create user on cognito
|
|
93
|
+
const signUpResult = yield this.auth.signUp({
|
|
94
|
+
username: requestResetResult.reset_username,
|
|
95
|
+
password: this.passwordService.getPassIdpString(passKeyBundle.passIdp),
|
|
96
|
+
clientMetadata: {
|
|
97
|
+
tp_password_reset_request: JSON.stringify({
|
|
98
|
+
id: requestResetResult.id,
|
|
99
|
+
associate_reset_user_token: requestResetResult.associate_reset_user_token,
|
|
100
|
+
}),
|
|
101
|
+
},
|
|
102
|
+
});
|
|
103
|
+
console.log('requestRest done: ', signUpResult);
|
|
104
|
+
return {
|
|
105
|
+
requestResetResult,
|
|
106
|
+
signUpResult,
|
|
107
|
+
};
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
getResetUser(reload = false) {
|
|
111
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
112
|
+
if (!reload && this.resetUser) {
|
|
113
|
+
return this.resetUser;
|
|
114
|
+
}
|
|
115
|
+
this.resetUser = yield this.lrAuth.loadResetUser();
|
|
116
|
+
return this.resetUser;
|
|
117
|
+
});
|
|
118
|
+
}
|
|
119
|
+
recoverAssemblyKey(resetUser) {
|
|
120
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
121
|
+
// Recover the assembly key.
|
|
122
|
+
let assemblyKeyParams;
|
|
123
|
+
const prk = yield this.keyGraphService.getKey(resetUser.pxk.id);
|
|
124
|
+
const shares = yield Promise.all(resetUser.approvals.map((approval) => __awaiter(this, void 0, void 0, function* () {
|
|
125
|
+
const partialAssemblyKey = yield this.encryptionService.decrypt(prk, approval.receiverCipherPartialAssemblyKey);
|
|
126
|
+
if (assemblyKeyParams) {
|
|
127
|
+
if (JSON.stringify(assemblyKeyParams) !==
|
|
128
|
+
JSON.stringify(partialAssemblyKey.assemblyKeyParams)) {
|
|
129
|
+
throw new LrBadStateException('The assembly key parameters are different between the approvals.');
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
else {
|
|
133
|
+
assemblyKeyParams = partialAssemblyKey.assemblyKeyParams;
|
|
134
|
+
}
|
|
135
|
+
return partialAssemblyKey.slip39.share.mnemonics;
|
|
136
|
+
})));
|
|
137
|
+
console.log('recoverAssemblyKey()', shares);
|
|
138
|
+
const rawAssemblyKey = yield this.slip39Service.recoverSecret(shares, TpPasswordResetService.SLIP39_PASSPHRASE);
|
|
139
|
+
return JWK.asKey(Object.assign(Object.assign({}, assemblyKeyParams), { k: rawAssemblyKey }));
|
|
140
|
+
});
|
|
141
|
+
}
|
|
142
|
+
completeRequest(newPassword) {
|
|
143
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
144
|
+
const resetUser = yield this.getResetUser(true);
|
|
145
|
+
if (resetUser.state !== TpClaimState.APPROVED) {
|
|
146
|
+
throw new LrBadStateException('Password reset request has not been approved.');
|
|
147
|
+
}
|
|
148
|
+
// --------------------------------------------------------------
|
|
149
|
+
// Prepare all materials to ensure there are no errors.
|
|
150
|
+
// --------------------------------------------------------------
|
|
151
|
+
const assemblyKey = yield this.recoverAssemblyKey(resetUser);
|
|
152
|
+
const { rootKey } = yield this.encryptionService.decrypt(assemblyKey, resetUser.assemblyCipherData);
|
|
153
|
+
console.log(rootKey);
|
|
154
|
+
// Making sure it's a valid key.
|
|
155
|
+
const rootKeyJwk = yield JWK.asKey(rootKey);
|
|
156
|
+
const masterKey = yield this.keyGraphService.getKey(resetUser.masterKey.id);
|
|
157
|
+
const masterKeyWrappedRootKey = yield this.encryptionService.encryptToString(masterKey.jwk, rootKeyJwk.toJSON(true));
|
|
158
|
+
// The new password
|
|
159
|
+
const newPassIdpResult = yield this.keyFactory.derivePassIdp(Object.assign({ password: newPassword }, resetUser.passKey.passIdpParams));
|
|
160
|
+
const newIdpPassword = this.passwordService.getPassIdpString(newPassIdpResult.jwk);
|
|
161
|
+
// --------------------------------------------------------------
|
|
162
|
+
// Get assembly key challenge
|
|
163
|
+
// --------------------------------------------------------------
|
|
164
|
+
const challenge = (yield this.mutate(new LrMutation({
|
|
165
|
+
mutation: CreateTpAssemblyKeyChallengeMutation,
|
|
166
|
+
variables: {
|
|
167
|
+
input: {},
|
|
168
|
+
},
|
|
169
|
+
}), {
|
|
170
|
+
includeKeyGraph: false,
|
|
171
|
+
})).createTpAssemblyKeyChallenge.challenge;
|
|
172
|
+
console.log(challenge);
|
|
173
|
+
// Sign the challenge
|
|
174
|
+
// Generate a client side nonce that's no in the server's control.
|
|
175
|
+
challenge.clientNonce = this.keyFactory.randomString(this.CLIENT_NONCE_LENGTH);
|
|
176
|
+
console.log(challenge);
|
|
177
|
+
const assemblyKeyVerifierPrk = yield this.encryptionService.decrypt(assemblyKey, resetUser.wrappedAssemblyKeyVerifierPrk);
|
|
178
|
+
const signedChallenge = yield this.encryptionService.sign(assemblyKeyVerifierPrk, challenge);
|
|
179
|
+
// --------------------------------------------------------------
|
|
180
|
+
// Change password for the original user
|
|
181
|
+
// --------------------------------------------------------------
|
|
182
|
+
const tempIdpPassword = (yield this.mutate(new LrMutation({
|
|
183
|
+
mutation: PreCompleteTpPasswordResetRequestMutation,
|
|
184
|
+
variables: {
|
|
185
|
+
input: {
|
|
186
|
+
signedChallenge: JSON.stringify(signedChallenge),
|
|
187
|
+
},
|
|
188
|
+
},
|
|
189
|
+
}), {
|
|
190
|
+
includeKeyGraph: false,
|
|
191
|
+
})).preCompleteTpPasswordResetRequest.idpPassword;
|
|
192
|
+
// --------------------------------------------------------------
|
|
193
|
+
// Login as the original user using new temporary password
|
|
194
|
+
// --------------------------------------------------------------
|
|
195
|
+
// At this point, the original account's password has been changed
|
|
196
|
+
// to a temporary password. It is no longer possible for the user
|
|
197
|
+
// to use the original password to login. Any successful login
|
|
198
|
+
// can only be using the temporary password. So it's safe to assume
|
|
199
|
+
// that we want to "complete" the password reset.
|
|
200
|
+
// The maybe 2FA so we listen for the auth event from Amplify.
|
|
201
|
+
const retPromise = new Promise((resolve) => {
|
|
202
|
+
const listener = (data) => __awaiter(this, void 0, void 0, function* () {
|
|
203
|
+
if (data.payload.event !== 'signIn') {
|
|
204
|
+
return;
|
|
205
|
+
}
|
|
206
|
+
Hub.remove('auth', listener);
|
|
207
|
+
console.log(data.payload);
|
|
208
|
+
yield this.auth.signIn(resetUser.username, newIdpPassword);
|
|
209
|
+
// Switch over to the new set of keys
|
|
210
|
+
yield this.mutate(new LrMutation({
|
|
211
|
+
mutation: CompleteTpPasswordResetRequestMutation,
|
|
212
|
+
variables: {
|
|
213
|
+
input: {
|
|
214
|
+
masterKeyWrappedRootKey,
|
|
215
|
+
masterKeyId: masterKey.id,
|
|
216
|
+
},
|
|
217
|
+
},
|
|
218
|
+
}));
|
|
219
|
+
resolve();
|
|
220
|
+
});
|
|
221
|
+
Hub.listen('auth', listener);
|
|
222
|
+
});
|
|
223
|
+
// Signin as the original user. Password has been reset to temporary one. It should return
|
|
224
|
+
// with NEW_PASSWORD_REQUIRED
|
|
225
|
+
let user = yield this.auth.signIn(resetUser.username, tempIdpPassword, {
|
|
226
|
+
noProxy: 'true',
|
|
227
|
+
});
|
|
228
|
+
if (user.challengeName !== 'NEW_PASSWORD_REQUIRED') {
|
|
229
|
+
throw new LrException({
|
|
230
|
+
message: 'Internal error. Expecting Cognito to have done a password reset after call to PreCompleteTpPasswordResetRequestMutation.',
|
|
231
|
+
});
|
|
232
|
+
}
|
|
233
|
+
// Set new password on Idp
|
|
234
|
+
// the awsFetch() function passes NEW_PASSWORD_REQUIRED directly to AWS without
|
|
235
|
+
// going through the proxy.
|
|
236
|
+
user = yield this.auth.completeNewPassword(user, newIdpPassword, {});
|
|
237
|
+
return retPromise;
|
|
238
|
+
});
|
|
239
|
+
}
|
|
240
|
+
};
|
|
241
|
+
TpPasswordResetUserService.ɵprov = i0.ɵɵdefineInjectable({ factory: function TpPasswordResetUserService_Factory() { return new TpPasswordResetUserService(i0.ɵɵinject(i0.NgZone), i0.ɵɵinject(i0.INJECTOR), i0.ɵɵinject(i1.LR_CONFIG), i0.ɵɵinject(i2.KeyFactoryService), i0.ɵɵinject(i3.EncryptionService), i0.ɵɵinject(i4.KeyGraphService), i0.ɵɵinject(i5.Slip39Service), i0.ɵɵinject(i6.PasswordService), i0.ɵɵinject(i7.HttpClient), i0.ɵɵinject(i8.AuthClass), i0.ɵɵinject(i9.LifeReadyAuthService)); }, token: TpPasswordResetUserService, providedIn: "root" });
|
|
242
|
+
TpPasswordResetUserService.decorators = [
|
|
243
|
+
{ type: Injectable, args: [{
|
|
244
|
+
providedIn: 'root',
|
|
245
|
+
},] }
|
|
246
|
+
];
|
|
247
|
+
TpPasswordResetUserService.ctorParameters = () => [
|
|
248
|
+
{ type: NgZone },
|
|
249
|
+
{ type: Injector },
|
|
250
|
+
{ type: undefined, decorators: [{ type: Inject, args: [LR_CONFIG,] }] },
|
|
251
|
+
{ type: KeyFactoryService },
|
|
252
|
+
{ type: EncryptionService },
|
|
253
|
+
{ type: KeyGraphService },
|
|
254
|
+
{ type: slip.Slip39Service },
|
|
255
|
+
{ type: PasswordService },
|
|
256
|
+
{ type: HttpClient },
|
|
257
|
+
{ type: AuthClass },
|
|
258
|
+
{ type: LifeReadyAuthService }
|
|
259
|
+
];
|
|
260
|
+
TpPasswordResetUserService = __decorate([
|
|
261
|
+
RunOutsideAngular({
|
|
262
|
+
ngZoneName: 'ngZone',
|
|
263
|
+
})
|
|
264
|
+
], TpPasswordResetUserService);
|
|
265
|
+
export { TpPasswordResetUserService };
|
|
266
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tp-password-reset-user.service.js","sourceRoot":"C:/Projects/test/projects/core/src/","sources":["lib/trusted-parties/tp-password-reset-user.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Hub } from '@aws-amplify/core';\r\nimport { Inject, Injectable, Injector, NgZone } from '@angular/core';\r\nimport { EncryptionService } from '../cryptography/encryption.service';\r\nimport { KeyGraphService } from '../cryptography/key-graph.service';\r\nimport { LifeReadyConfig, LR_CONFIG } from '../life-ready.config';\r\nimport * as slip from '../cryptography/slip39.service';\r\nimport { JWK } from 'node-jose';\r\nimport { LrBadStateException, LrException } from '../_common/exceptions';\r\nimport {\r\n  CompleteTpPasswordResetRequestMutation,\r\n  CreateTpAssemblyKeyChallengeMutation,\r\n  PreCompleteTpPasswordResetRequestMutation,\r\n} from './tp-password-reset.gql';\r\nimport { PasswordService } from '../auth/password.service';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { AuthClass } from '@aws-amplify/auth/lib-esm/Auth';\r\nimport {\r\n  RequestResetResult,\r\n  TpPasswordResetService,\r\n} from './tp-password-reset.service';\r\nimport { ISignUpResult } from 'amazon-cognito-identity-js';\r\nimport { LifeReadyAuthService } from '../auth/life-ready-auth.service';\r\nimport { KeyFactoryService } from '../cryptography/key-factory.service';\r\nimport { TpClaimState, TpPasswordResetUserNode } from '../api/types';\r\nimport { LrMutation, LrService } from '../api/lr-graphql';\r\nimport { RunOutsideAngular } from '../_common/run-outside-angular';\r\n\r\n@RunOutsideAngular({\r\n  ngZoneName: 'ngZone',\r\n})\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class TpPasswordResetUserService extends LrService {\r\n  private readonly CLIENT_NONCE_LENGTH = 32;\r\n  private resetUser: TpPasswordResetUserNode;\r\n\r\n  constructor(\r\n    private ngZone: NgZone,\r\n    private injector: Injector,\r\n    @Inject(LR_CONFIG) private config: LifeReadyConfig,\r\n    private keyFactory: KeyFactoryService,\r\n    private encryptionService: EncryptionService,\r\n    private keyGraphService: KeyGraphService,\r\n    private slip39Service: slip.Slip39Service,\r\n    private passwordService: PasswordService,\r\n    private http: HttpClient,\r\n    private auth: AuthClass,\r\n    private lrAuth: LifeReadyAuthService\r\n  ) {\r\n    super(injector);\r\n  }\r\n\r\n  async verifyEmailContact(email): Promise<{ claimId: string }> {\r\n    const params = {\r\n      email,\r\n    };\r\n    return this.http\r\n      .post<any>(\r\n        `${this.config.authUrl}tp/password-reset/verify-contact/`,\r\n        params\r\n      )\r\n      .toPromise();\r\n  }\r\n\r\n  async verifyContactRespond(\r\n    claimId: string,\r\n    claimCode: string\r\n  ): Promise<string> {\r\n    const { token } = await this.http\r\n      .post<{ token }>(`${this.config.authUrl}cove/respond/`, {\r\n        claim_id: claimId,\r\n        v_code: claimCode,\r\n      })\r\n      .toPromise();\r\n    return token;\r\n  }\r\n\r\n  async requestReset(\r\n    password: string,\r\n    claimId: string,\r\n    claimToken: string\r\n  ): Promise<{\r\n    requestResetResult: RequestResetResult;\r\n    signUpResult: ISignUpResult;\r\n  }> {\r\n    // Generate the key materials\r\n    const passKeyBundle = await this.passwordService.createPassKeyBundle(\r\n      password\r\n    );\r\n\r\n    const masterKey = await this.keyFactory.createKey();\r\n    const wrappedMasterKey = await this.encryptionService.encrypt(\r\n      passKeyBundle.passKey,\r\n      masterKey.toJSON(true)\r\n    );\r\n\r\n    // Ephemeral PKC key\r\n    const prk = await this.keyFactory.createPkcKey();\r\n    const masterKeyWrappedPrk = await this.encryptionService.encrypt(\r\n      masterKey,\r\n      prk.toJSON(true)\r\n    );\r\n\r\n    // API call to setup reset request\r\n    const requestResetResult = await this.http\r\n      .post<RequestResetResult>(\r\n        `${this.config.authUrl}tp/password-reset/request/`,\r\n        {\r\n          claimId,\r\n          claimToken,\r\n          pass_key_params: passKeyBundle.passKeyParams,\r\n          pass_idp_params: passKeyBundle.passIdpParams,\r\n          pass_idp_verifier_pbk: passKeyBundle.passIdpVerifier.toJSON(), // public key\r\n          wrapped_pass_idp_verifier_prk:\r\n            passKeyBundle.wrappedPassIdpVerifierPrk,\r\n          wrapped_master_key: wrappedMasterKey,\r\n          pbk: prk.toJSON(), // ephemeral public key\r\n          master_key_wrapped_prk: masterKeyWrappedPrk,\r\n        }\r\n      )\r\n      .toPromise();\r\n\r\n    console.log(requestResetResult);\r\n    console.log(\r\n      'Using new password: ',\r\n      this.passwordService.getPassIdpString(passKeyBundle.passIdp)\r\n    );\r\n\r\n    // API call to create user on cognito\r\n    const signUpResult = await this.auth.signUp({\r\n      username: requestResetResult.reset_username,\r\n      password: this.passwordService.getPassIdpString(passKeyBundle.passIdp),\r\n      clientMetadata: {\r\n        tp_password_reset_request: JSON.stringify({\r\n          id: requestResetResult.id,\r\n          associate_reset_user_token:\r\n            requestResetResult.associate_reset_user_token,\r\n        }),\r\n      },\r\n    });\r\n\r\n    console.log('requestRest done: ', signUpResult);\r\n\r\n    return {\r\n      requestResetResult,\r\n      signUpResult,\r\n    };\r\n  }\r\n\r\n  async getResetUser(\r\n    reload: boolean = false\r\n  ): Promise<TpPasswordResetUserNode> {\r\n    if (!reload && this.resetUser) {\r\n      return this.resetUser;\r\n    }\r\n    this.resetUser = await this.lrAuth.loadResetUser();\r\n    return this.resetUser;\r\n  }\r\n\r\n  private async recoverAssemblyKey(\r\n    resetUser: TpPasswordResetUserNode\r\n  ): Promise<JWK.Key> {\r\n    // Recover the assembly key.\r\n    let assemblyKeyParams: object;\r\n\r\n    const prk = await this.keyGraphService.getKey(resetUser.pxk.id);\r\n\r\n    const shares = await Promise.all(\r\n      resetUser.approvals.map(async (approval) => {\r\n        const partialAssemblyKey = await this.encryptionService.decrypt(\r\n          prk,\r\n          approval.receiverCipherPartialAssemblyKey\r\n        );\r\n\r\n        if (assemblyKeyParams) {\r\n          if (\r\n            JSON.stringify(assemblyKeyParams) !==\r\n            JSON.stringify(partialAssemblyKey.assemblyKeyParams)\r\n          ) {\r\n            throw new LrBadStateException(\r\n              'The assembly key parameters are different between the approvals.'\r\n            );\r\n          }\r\n        } else {\r\n          assemblyKeyParams = partialAssemblyKey.assemblyKeyParams;\r\n        }\r\n        return partialAssemblyKey.slip39.share.mnemonics;\r\n      })\r\n    );\r\n\r\n    console.log('recoverAssemblyKey()', shares);\r\n\r\n    const rawAssemblyKey = await this.slip39Service.recoverSecret(\r\n      shares,\r\n      TpPasswordResetService.SLIP39_PASSPHRASE\r\n    );\r\n\r\n    return JWK.asKey({\r\n      ...assemblyKeyParams,\r\n      k: rawAssemblyKey,\r\n    });\r\n  }\r\n\r\n  async completeRequest(newPassword: string): Promise<void> {\r\n    const resetUser = await this.getResetUser(true);\r\n    if (resetUser.state !== TpClaimState.APPROVED) {\r\n      throw new LrBadStateException(\r\n        'Password reset request has not been approved.'\r\n      );\r\n    }\r\n\r\n    // --------------------------------------------------------------\r\n    // Prepare all materials to ensure there are no errors.\r\n    // --------------------------------------------------------------\r\n    const assemblyKey = await this.recoverAssemblyKey(resetUser);\r\n\r\n    const { rootKey } = await this.encryptionService.decrypt(\r\n      assemblyKey,\r\n      resetUser.assemblyCipherData\r\n    );\r\n    console.log(rootKey);\r\n\r\n    // Making sure it's a valid key.\r\n    const rootKeyJwk = await JWK.asKey(rootKey);\r\n\r\n    const masterKey = await this.keyGraphService.getKey(resetUser.masterKey.id);\r\n\r\n    const masterKeyWrappedRootKey = await this.encryptionService.encryptToString(\r\n      masterKey.jwk,\r\n      rootKeyJwk.toJSON(true)\r\n    );\r\n\r\n    // The new password\r\n    const newPassIdpResult = await this.keyFactory.derivePassIdp({\r\n      password: newPassword,\r\n      ...resetUser.passKey.passIdpParams,\r\n    });\r\n\r\n    const newIdpPassword = this.passwordService.getPassIdpString(\r\n      newPassIdpResult.jwk\r\n    );\r\n\r\n    // --------------------------------------------------------------\r\n    // Get assembly key challenge\r\n    // --------------------------------------------------------------\r\n    const challenge = (\r\n      await this.mutate(\r\n        new LrMutation({\r\n          mutation: CreateTpAssemblyKeyChallengeMutation,\r\n          variables: {\r\n            input: {},\r\n          },\r\n        }),\r\n        {\r\n          includeKeyGraph: false,\r\n        }\r\n      )\r\n    ).createTpAssemblyKeyChallenge.challenge;\r\n\r\n    console.log(challenge);\r\n\r\n    // Sign the challenge\r\n    // Generate a client side nonce that's no in the server's control.\r\n    challenge.clientNonce = this.keyFactory.randomString(\r\n      this.CLIENT_NONCE_LENGTH\r\n    );\r\n    console.log(challenge);\r\n\r\n    const assemblyKeyVerifierPrk = await this.encryptionService.decrypt(\r\n      assemblyKey,\r\n      resetUser.wrappedAssemblyKeyVerifierPrk\r\n    );\r\n    const signedChallenge = await this.encryptionService.sign(\r\n      assemblyKeyVerifierPrk,\r\n      challenge\r\n    );\r\n\r\n    // --------------------------------------------------------------\r\n    // Change password for the original user\r\n    // --------------------------------------------------------------\r\n    const tempIdpPassword = (\r\n      await this.mutate(\r\n        new LrMutation({\r\n          mutation: PreCompleteTpPasswordResetRequestMutation,\r\n          variables: {\r\n            input: {\r\n              signedChallenge: JSON.stringify(signedChallenge),\r\n            },\r\n          },\r\n        }),\r\n        {\r\n          includeKeyGraph: false,\r\n        }\r\n      )\r\n    ).preCompleteTpPasswordResetRequest.idpPassword;\r\n\r\n    // --------------------------------------------------------------\r\n    // Login as the original user using new temporary password\r\n    // --------------------------------------------------------------\r\n    // At this point, the original account's password has been changed\r\n    // to a temporary password. It is no longer possible for the user\r\n    // to use the original password to login. Any successful login\r\n    // can only be using the temporary password. So it's safe to assume\r\n    // that we want to \"complete\" the password reset.\r\n\r\n    // The maybe 2FA so we listen for the auth event from Amplify.\r\n    const retPromise = new Promise<void>((resolve) => {\r\n      const listener = async (data) => {\r\n        if (data.payload.event !== 'signIn') {\r\n          return;\r\n        }\r\n\r\n        Hub.remove('auth', listener);\r\n\r\n        console.log(data.payload);\r\n\r\n        await this.auth.signIn(resetUser.username, newIdpPassword);\r\n\r\n        // Switch over to the new set of keys\r\n        await this.mutate(\r\n          new LrMutation({\r\n            mutation: CompleteTpPasswordResetRequestMutation,\r\n            variables: {\r\n              input: {\r\n                masterKeyWrappedRootKey,\r\n                masterKeyId: masterKey.id,\r\n              },\r\n            },\r\n          })\r\n        );\r\n\r\n        resolve();\r\n      };\r\n\r\n      Hub.listen('auth', listener);\r\n    });\r\n\r\n    // Signin as the original user. Password has been reset to temporary one. It should return\r\n    // with NEW_PASSWORD_REQUIRED\r\n    let user = await this.auth.signIn(resetUser.username, tempIdpPassword, {\r\n      noProxy: 'true',\r\n    });\r\n\r\n    if (user.challengeName !== 'NEW_PASSWORD_REQUIRED') {\r\n      throw new LrException({\r\n        message:\r\n          'Internal error. Expecting Cognito to have done a password reset after call to PreCompleteTpPasswordResetRequestMutation.',\r\n      });\r\n    }\r\n\r\n    // Set new password on Idp\r\n    // the awsFetch() function passes NEW_PASSWORD_REQUIRED directly to AWS without\r\n    // going through the proxy.\r\n    user = await this.auth.completeNewPassword(user, newIdpPassword, {});\r\n\r\n    return retPromise;\r\n  }\r\n}\r\n"]}
|
|
@@ -0,0 +1,232 @@
|
|
|
1
|
+
import { gqlTyped } from '../_common/ast';
|
|
2
|
+
const SharedTpPasswordResetFragment = gqlTyped `
|
|
3
|
+
fragment SharedTpPasswordResetFragment on SharedTpPasswordResetNode {
|
|
4
|
+
id
|
|
5
|
+
tp {
|
|
6
|
+
id
|
|
7
|
+
other {
|
|
8
|
+
username
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
assembly {
|
|
12
|
+
asApprovers {
|
|
13
|
+
edges {
|
|
14
|
+
node {
|
|
15
|
+
id
|
|
16
|
+
sharedKey {
|
|
17
|
+
id
|
|
18
|
+
}
|
|
19
|
+
sharedCipherData
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
sharedRequest {
|
|
25
|
+
id
|
|
26
|
+
pxk {
|
|
27
|
+
id
|
|
28
|
+
pbk
|
|
29
|
+
}
|
|
30
|
+
claim {
|
|
31
|
+
id
|
|
32
|
+
state
|
|
33
|
+
asClaimApprovers {
|
|
34
|
+
edges {
|
|
35
|
+
node {
|
|
36
|
+
id
|
|
37
|
+
state
|
|
38
|
+
sharedKey {
|
|
39
|
+
id
|
|
40
|
+
}
|
|
41
|
+
sharedCipherApprovalData
|
|
42
|
+
sharedCipherPartialAssemblyKey
|
|
43
|
+
receiverApprovals {
|
|
44
|
+
edges {
|
|
45
|
+
node {
|
|
46
|
+
id
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
}`;
|
|
56
|
+
export const SharedTpPasswordResetsQuery = gqlTyped `
|
|
57
|
+
query SharedTpPasswordResetsQuery {
|
|
58
|
+
sharedTpPasswordResets {
|
|
59
|
+
edges {
|
|
60
|
+
node {
|
|
61
|
+
...SharedTpPasswordResetFragment
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
${SharedTpPasswordResetFragment}
|
|
67
|
+
`;
|
|
68
|
+
export const SharedTpPasswordResetQuery = gqlTyped `
|
|
69
|
+
query SharedTpPasswordResetQuery($id: LrRelayIdInput!) {
|
|
70
|
+
sharedTpPasswordReset(id: $id) {
|
|
71
|
+
...SharedTpPasswordResetFragment
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
${SharedTpPasswordResetFragment}
|
|
75
|
+
`;
|
|
76
|
+
export const CancelTpPasswordResetRequestMutation = gqlTyped `
|
|
77
|
+
mutation CancelTpPasswordResetRequestMutation {
|
|
78
|
+
cancelTpPasswordResetRequest(input: {}) {
|
|
79
|
+
id
|
|
80
|
+
}
|
|
81
|
+
}`;
|
|
82
|
+
export const CreateTpAssemblyKeyChallengeMutation = gqlTyped `
|
|
83
|
+
mutation CreateTpAssemblyKeyChallengeMutation(
|
|
84
|
+
$input: CreateTpAssemblyKeyChallengeInput!
|
|
85
|
+
) {
|
|
86
|
+
createTpAssemblyKeyChallenge(input: $input) {
|
|
87
|
+
challenge
|
|
88
|
+
}
|
|
89
|
+
}`;
|
|
90
|
+
export const PreCompleteTpPasswordResetRequestMutation = gqlTyped `
|
|
91
|
+
mutation PreCompleteTpPasswordResetRequestMutation(
|
|
92
|
+
$input: PreCompleteTpPasswordResetRequestInput!
|
|
93
|
+
) {
|
|
94
|
+
preCompleteTpPasswordResetRequest(input: $input) {
|
|
95
|
+
idpPassword
|
|
96
|
+
}
|
|
97
|
+
}`;
|
|
98
|
+
export const CompleteTpPasswordResetRequestMutation = gqlTyped `
|
|
99
|
+
mutation CompleteTpPasswordResetRequestMutation(
|
|
100
|
+
$input: CompleteTpPasswordResetRequestInput!
|
|
101
|
+
) {
|
|
102
|
+
completeTpPasswordResetRequest(input: $input) {
|
|
103
|
+
id
|
|
104
|
+
}
|
|
105
|
+
}`;
|
|
106
|
+
export const ApproveTpPasswordResetRequestMutation = gqlTyped `
|
|
107
|
+
mutation ApproveTpPasswordResetRequestMutation(
|
|
108
|
+
$input: ApproveTpPasswordResetRequestInput!
|
|
109
|
+
) {
|
|
110
|
+
approveTpPasswordResetRequest(input: $input) {
|
|
111
|
+
claimApprover {
|
|
112
|
+
id
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
}`;
|
|
116
|
+
export const RejectTpPasswordResetRequestMutation = gqlTyped `
|
|
117
|
+
mutation RejectTpPasswordResetRequestMutation(
|
|
118
|
+
$input: RejectTpPasswordResetRequestInput!
|
|
119
|
+
) {
|
|
120
|
+
rejectTpPasswordResetRequest(input: $input) {
|
|
121
|
+
claimApprover {
|
|
122
|
+
id
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
}`;
|
|
126
|
+
export const TpPasswordResetUserQuery = gqlTyped `
|
|
127
|
+
query TpPasswordResetUserQuery {
|
|
128
|
+
tpPasswordResetUser {
|
|
129
|
+
username
|
|
130
|
+
resetUsername
|
|
131
|
+
state
|
|
132
|
+
passKey {
|
|
133
|
+
id
|
|
134
|
+
passKeyParams
|
|
135
|
+
passIdpParams
|
|
136
|
+
}
|
|
137
|
+
masterKey {
|
|
138
|
+
id
|
|
139
|
+
}
|
|
140
|
+
pxk {
|
|
141
|
+
id
|
|
142
|
+
}
|
|
143
|
+
sessionEncryptionKey
|
|
144
|
+
assembly {
|
|
145
|
+
singleReject
|
|
146
|
+
quorum
|
|
147
|
+
subAssemblies {
|
|
148
|
+
singleReject
|
|
149
|
+
quorum
|
|
150
|
+
approvers {
|
|
151
|
+
name
|
|
152
|
+
email
|
|
153
|
+
state
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
approvals {
|
|
158
|
+
id
|
|
159
|
+
modified
|
|
160
|
+
approverEmail
|
|
161
|
+
receiverCipher
|
|
162
|
+
receiverCipherPartialAssemblyKey
|
|
163
|
+
}
|
|
164
|
+
assemblyCipherData
|
|
165
|
+
wrappedAssemblyKeyVerifierPrk
|
|
166
|
+
}
|
|
167
|
+
}`;
|
|
168
|
+
export const TpPasswordResetQuery = gqlTyped `
|
|
169
|
+
query TpPasswordResetQuery {
|
|
170
|
+
tpPasswordReset {
|
|
171
|
+
id
|
|
172
|
+
applied
|
|
173
|
+
assembly {
|
|
174
|
+
singleReject
|
|
175
|
+
quorum
|
|
176
|
+
subjectKey {
|
|
177
|
+
id
|
|
178
|
+
}
|
|
179
|
+
assemblyKey {
|
|
180
|
+
id
|
|
181
|
+
}
|
|
182
|
+
assemblyCipherData
|
|
183
|
+
subAssemblies {
|
|
184
|
+
edges {
|
|
185
|
+
node {
|
|
186
|
+
id
|
|
187
|
+
singleReject
|
|
188
|
+
quorum
|
|
189
|
+
subjectCipherData
|
|
190
|
+
approvers {
|
|
191
|
+
edges {
|
|
192
|
+
node {
|
|
193
|
+
id
|
|
194
|
+
tp {
|
|
195
|
+
id
|
|
196
|
+
}
|
|
197
|
+
sharedKey {
|
|
198
|
+
id
|
|
199
|
+
}
|
|
200
|
+
sharedCipherData
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
}
|
|
209
|
+
}`;
|
|
210
|
+
export const CreateTpPasswordResetMutation = gqlTyped `
|
|
211
|
+
mutation CreateTpPasswordResetMutation($input: CreateTpPasswordResetInput!) {
|
|
212
|
+
createTpPasswordReset(input: $input) {
|
|
213
|
+
tpPasswordReset {
|
|
214
|
+
id
|
|
215
|
+
}
|
|
216
|
+
}
|
|
217
|
+
}`;
|
|
218
|
+
export const DeleteTpPasswordResetMutation = gqlTyped `
|
|
219
|
+
mutation DeleteTpPasswordResetMutation {
|
|
220
|
+
deleteTpPasswordReset(input: {}) {
|
|
221
|
+
id
|
|
222
|
+
}
|
|
223
|
+
}`;
|
|
224
|
+
export const UpdateTpPasswordResetMutation = gqlTyped `
|
|
225
|
+
mutation UpdateTpPasswordResetMutation($input: UpdateTpPasswordResetInput!) {
|
|
226
|
+
updateTpPasswordReset(input: $input) {
|
|
227
|
+
tpPasswordReset {
|
|
228
|
+
id
|
|
229
|
+
}
|
|
230
|
+
}
|
|
231
|
+
}`;
|
|
232
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tp-password-reset.gql.js","sourceRoot":"C:/Projects/test/projects/core/src/","sources":["lib/trusted-parties/tp-password-reset.gql.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AA+D1C,MAAM,6BAA6B,GAAG,QAAQ,CAAqC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAqDjF,CAAC;AASH,MAAM,CAAC,MAAM,2BAA2B,GAAG,QAAQ,CAAmC;;;;;;;;;;EAUpF,6BAA6B;CAC9B,CAAC;AAKF,MAAM,CAAC,MAAM,0BAA0B,GAAG,QAAQ,CAAkC;;;;;;EAMlF,6BAA6B;CAC9B,CAAC;AAOF,MAAM,CAAC,MAAM,oCAAoC,GAAG,QAAQ,CAA4C;;;;;EAKtG,CAAC;AAOH,MAAM,CAAC,MAAM,oCAAoC,GAAG,QAAQ,CAA4C;;;;;;;EAOtG,CAAC;AAOH,MAAM,CAAC,MAAM,yCAAyC,GAAG,QAAQ,CAAiD;;;;;;;EAOhH,CAAC;AAOH,MAAM,CAAC,MAAM,sCAAsC,GAAG,QAAQ,CAA8C;;;;;;;EAO1G,CAAC;AASH,MAAM,CAAC,MAAM,qCAAqC,GAAG,QAAQ,CAA6C;;;;;;;;;EASxG,CAAC;AASH,MAAM,CAAC,MAAM,oCAAoC,GAAG,QAAQ,CAA4C;;;;;;;;;EAStG,CAAC;AA2CH,MAAM,CAAC,MAAM,wBAAwB,GAAG,QAAQ,CAAgC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAyC9E,CAAC;AA4CH,MAAM,CAAC,MAAM,oBAAoB,GAAG,QAAQ,CAA4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAyCtE,CAAC;AASH,MAAM,CAAC,MAAM,6BAA6B,GAAG,QAAQ,CAAqC;;;;;;;EAOxF,CAAC;AAOH,MAAM,CAAC,MAAM,6BAA6B,GAAG,QAAQ,CAAqC;;;;;EAKxF,CAAC;AASH,MAAM,CAAC,MAAM,6BAA6B,GAAG,QAAQ,CAAqC;;;;;;;EAOxF,CAAC","sourcesContent":["import { GenericScalar, ID } from '../api/types';\r\nimport { gqlTyped } from '../_common/ast';\r\nimport {\r\n  TpClaimState,\r\n  TpClaimApproverState,\r\n} from '../api/types/lr-graphql.types';\r\nimport { DateTime } from '../api/types/graphql.types';\r\n\r\nexport interface SharedTpPasswordResetFragmentResult {\r\n  id: ID;\r\n  tp: {\r\n    id: ID;\r\n    other: {\r\n      username: string;\r\n    };\r\n  };\r\n  assembly: {\r\n    asApprovers: {\r\n      edges: {\r\n        node: {\r\n          id: ID;\r\n          sharedKey: {\r\n            id: ID;\r\n          };\r\n          sharedCipherData: string;\r\n          sharedCipherDataClearJson: any;\r\n        };\r\n      }[];\r\n    };\r\n  };\r\n  sharedRequest: {\r\n    id: ID;\r\n    pxk: {\r\n      id: ID;\r\n      pbk: string;\r\n    };\r\n    claim: {\r\n      id: ID;\r\n      state: TpClaimState;\r\n      asClaimApprovers: {\r\n        edges: {\r\n          node: {\r\n            id: ID;\r\n            state: TpClaimApproverState;\r\n            sharedKey: {\r\n              id: ID;\r\n            };\r\n            sharedCipherApprovalData: string;\r\n            sharedCipherApprovalDataClearJson: any;\r\n            sharedCipherPartialAssemblyKey: string;\r\n            sharedCipherPartialAssemblyKeyClearJson: any;\r\n            receiverApprovals: {\r\n              edges: {\r\n                node: {\r\n                  id: ID;\r\n                };\r\n              }[];\r\n            };\r\n          };\r\n        }[];\r\n      };\r\n    };\r\n  };\r\n}\r\nconst SharedTpPasswordResetFragment = gqlTyped<SharedTpPasswordResetFragmentResult>`\r\nfragment SharedTpPasswordResetFragment on SharedTpPasswordResetNode {\r\n  id\r\n  tp {\r\n    id\r\n    other {\r\n      username\r\n    }\r\n  }\r\n  assembly {\r\n    asApprovers {\r\n      edges {\r\n        node {\r\n          id\r\n          sharedKey {\r\n            id\r\n          }\r\n          sharedCipherData\r\n        }\r\n      }\r\n    }\r\n  }\r\n  sharedRequest {\r\n    id\r\n    pxk {\r\n      id\r\n      pbk\r\n    }\r\n    claim {\r\n      id\r\n      state\r\n      asClaimApprovers {\r\n        edges {\r\n          node {\r\n            id\r\n            state\r\n            sharedKey {\r\n              id\r\n            }\r\n            sharedCipherApprovalData\r\n            sharedCipherPartialAssemblyKey\r\n            receiverApprovals {\r\n              edges {\r\n                node {\r\n                  id\r\n                }\r\n              }\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n}`;\r\n\r\nexport interface SharedTpPasswordResetsQueryResult {\r\n  sharedTpPasswordResets: {\r\n    edges: {\r\n      node: SharedTpPasswordResetFragmentResult;\r\n    }[];\r\n  };\r\n}\r\nexport const SharedTpPasswordResetsQuery = gqlTyped<SharedTpPasswordResetsQueryResult>`\r\nquery SharedTpPasswordResetsQuery {\r\n  sharedTpPasswordResets {\r\n    edges {\r\n      node {\r\n        ...SharedTpPasswordResetFragment\r\n      }\r\n    }\r\n  }\r\n}\r\n${SharedTpPasswordResetFragment}\r\n`;\r\n\r\nexport interface SharedTpPasswordResetQueryResult {\r\n  sharedTpPasswordReset: SharedTpPasswordResetFragmentResult;\r\n}\r\nexport const SharedTpPasswordResetQuery = gqlTyped<SharedTpPasswordResetQueryResult>`\r\nquery SharedTpPasswordResetQuery($id: LrRelayIdInput!) {\r\n  sharedTpPasswordReset(id: $id) {\r\n    ...SharedTpPasswordResetFragment\r\n  }\r\n}\r\n${SharedTpPasswordResetFragment}\r\n`;\r\n\r\nexport interface CancelTpPasswordResetRequestMutationResult {\r\n  cancelTpPasswordResetRequest: {\r\n    id: ID;\r\n  };\r\n}\r\nexport const CancelTpPasswordResetRequestMutation = gqlTyped<CancelTpPasswordResetRequestMutationResult>`\r\nmutation CancelTpPasswordResetRequestMutation {\r\n  cancelTpPasswordResetRequest(input: {}) {\r\n    id\r\n  }\r\n}`;\r\n\r\nexport interface CreateTpAssemblyKeyChallengeMutationResult {\r\n  createTpAssemblyKeyChallenge: {\r\n    challenge: any;\r\n  };\r\n}\r\nexport const CreateTpAssemblyKeyChallengeMutation = gqlTyped<CreateTpAssemblyKeyChallengeMutationResult>`\r\nmutation CreateTpAssemblyKeyChallengeMutation(\r\n  $input: CreateTpAssemblyKeyChallengeInput!\r\n) {\r\n  createTpAssemblyKeyChallenge(input: $input) {\r\n    challenge\r\n  }\r\n}`;\r\n\r\nexport interface PreCompleteTpPasswordResetRequestMutationResult {\r\n  preCompleteTpPasswordResetRequest: {\r\n    idpPassword: string;\r\n  };\r\n}\r\nexport const PreCompleteTpPasswordResetRequestMutation = gqlTyped<PreCompleteTpPasswordResetRequestMutationResult>`\r\nmutation PreCompleteTpPasswordResetRequestMutation(\r\n  $input: PreCompleteTpPasswordResetRequestInput!\r\n) {\r\n  preCompleteTpPasswordResetRequest(input: $input) {\r\n    idpPassword\r\n  }\r\n}`;\r\n\r\nexport interface CompleteTpPasswordResetRequestMutationResult {\r\n  completeTpPasswordResetRequest: {\r\n    id: ID;\r\n  };\r\n}\r\nexport const CompleteTpPasswordResetRequestMutation = gqlTyped<CompleteTpPasswordResetRequestMutationResult>`\r\nmutation CompleteTpPasswordResetRequestMutation(\r\n  $input: CompleteTpPasswordResetRequestInput!\r\n) {\r\n  completeTpPasswordResetRequest(input: $input) {\r\n    id\r\n  }\r\n}`;\r\n\r\nexport interface ApproveTpPasswordResetRequestMutationResult {\r\n  approveTpPasswordResetRequest: {\r\n    claimApprover: {\r\n      id: ID;\r\n    };\r\n  };\r\n}\r\nexport const ApproveTpPasswordResetRequestMutation = gqlTyped<ApproveTpPasswordResetRequestMutationResult>`\r\nmutation ApproveTpPasswordResetRequestMutation(\r\n  $input: ApproveTpPasswordResetRequestInput!\r\n) {\r\n  approveTpPasswordResetRequest(input: $input) {\r\n    claimApprover {\r\n      id\r\n    }\r\n  }\r\n}`;\r\n\r\nexport interface RejectTpPasswordResetRequestMutationResult {\r\n  rejectTpPasswordResetRequest: {\r\n    claimApprover: {\r\n      id: ID;\r\n    };\r\n  };\r\n}\r\nexport const RejectTpPasswordResetRequestMutation = gqlTyped<RejectTpPasswordResetRequestMutationResult>`\r\nmutation RejectTpPasswordResetRequestMutation(\r\n  $input: RejectTpPasswordResetRequestInput!\r\n) {\r\n  rejectTpPasswordResetRequest(input: $input) {\r\n    claimApprover {\r\n      id\r\n    }\r\n  }\r\n}`;\r\n\r\nexport interface TpPasswordResetUserQueryResult {\r\n  tpPasswordResetUser: {\r\n    username: string;\r\n    resetUsername: string;\r\n    state: TpClaimState;\r\n    passKey: {\r\n      id: ID;\r\n      passKeyParams: GenericScalar;\r\n      passIdpParams: GenericScalar;\r\n    };\r\n    masterKey: {\r\n      id: ID;\r\n    };\r\n    pxk: {\r\n      id: ID;\r\n    };\r\n    sessionEncryptionKey: string;\r\n    assembly: {\r\n      singleReject: boolean;\r\n      quorum: number;\r\n      subAssemblies: {\r\n        singleReject: boolean;\r\n        quorum: number;\r\n        approvers: {\r\n          name: string;\r\n          email: string;\r\n          state: TpClaimApproverState;\r\n        }[];\r\n      }[];\r\n    };\r\n    approvals: {\r\n      id: ID;\r\n      modified: DateTime;\r\n      approverEmail: string;\r\n      receiverCipher: string;\r\n      receiverCipherPartialAssemblyKey: string;\r\n    }[];\r\n    assemblyCipherData: string;\r\n    wrappedAssemblyKeyVerifierPrk: string;\r\n  };\r\n}\r\nexport const TpPasswordResetUserQuery = gqlTyped<TpPasswordResetUserQueryResult>`\r\nquery TpPasswordResetUserQuery {\r\n  tpPasswordResetUser {\r\n    username\r\n    resetUsername\r\n    state\r\n    passKey {\r\n      id\r\n      passKeyParams\r\n      passIdpParams\r\n    }\r\n    masterKey {\r\n      id\r\n    }\r\n    pxk {\r\n      id\r\n    }\r\n    sessionEncryptionKey\r\n    assembly {\r\n      singleReject\r\n      quorum\r\n      subAssemblies {\r\n        singleReject\r\n        quorum\r\n        approvers {\r\n          name\r\n          email\r\n          state\r\n        }\r\n      }\r\n    }\r\n    approvals {\r\n      id\r\n      modified\r\n      approverEmail\r\n      receiverCipher\r\n      receiverCipherPartialAssemblyKey\r\n    }\r\n    assemblyCipherData\r\n    wrappedAssemblyKeyVerifierPrk\r\n  }\r\n}`;\r\n\r\nexport interface TpPasswordResetQueryResult {\r\n  tpPasswordReset: {\r\n    id: ID;\r\n    applied: boolean;\r\n    assembly: {\r\n      singleReject: boolean;\r\n      quorum: number;\r\n      subjectKey: {\r\n        id: ID;\r\n      };\r\n      assemblyKey: {\r\n        id: ID;\r\n      };\r\n      assemblyCipherData: string;\r\n      subAssemblies: {\r\n        edges: {\r\n          node: {\r\n            id: ID;\r\n            singleReject: boolean;\r\n            quorum: number;\r\n            subjectCipherData: string;\r\n            subjectCipherDataClearJson: any;\r\n            approvers: {\r\n              edges: {\r\n                node: {\r\n                  id: ID;\r\n                  tp: {\r\n                    id: ID;\r\n                  };\r\n                  sharedKey: {\r\n                    id: ID;\r\n                  };\r\n                  sharedCipherData: string;\r\n                };\r\n              }[];\r\n            };\r\n          };\r\n        }[];\r\n      };\r\n    };\r\n  };\r\n}\r\nexport const TpPasswordResetQuery = gqlTyped<TpPasswordResetQueryResult>`\r\nquery TpPasswordResetQuery {\r\n  tpPasswordReset {\r\n    id\r\n    applied\r\n    assembly {\r\n      singleReject\r\n      quorum\r\n      subjectKey {\r\n        id\r\n      }\r\n      assemblyKey {\r\n        id\r\n      }\r\n      assemblyCipherData\r\n      subAssemblies {\r\n        edges {\r\n          node {\r\n            id\r\n            singleReject\r\n            quorum\r\n            subjectCipherData\r\n            approvers {\r\n              edges {\r\n                node {\r\n                  id\r\n                  tp {\r\n                    id\r\n                  }\r\n                  sharedKey {\r\n                    id\r\n                  }\r\n                  sharedCipherData\r\n                }\r\n              }\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n}`;\r\n\r\nexport interface CreateTpPasswordResetMutationResult {\r\n  createTpPasswordReset: {\r\n    tpPasswordReset: {\r\n      id: ID;\r\n    };\r\n  };\r\n}\r\nexport const CreateTpPasswordResetMutation = gqlTyped<CreateTpPasswordResetMutationResult>`\r\nmutation CreateTpPasswordResetMutation($input: CreateTpPasswordResetInput!) {\r\n  createTpPasswordReset(input: $input) {\r\n    tpPasswordReset {\r\n      id\r\n    }\r\n  }\r\n}`;\r\n\r\nexport interface DeleteTpPasswordResetMutationResult {\r\n  deleteTpPasswordReset: {\r\n    id: ID;\r\n  };\r\n}\r\nexport const DeleteTpPasswordResetMutation = gqlTyped<DeleteTpPasswordResetMutationResult>`\r\nmutation DeleteTpPasswordResetMutation {\r\n  deleteTpPasswordReset(input: {}) {\r\n    id\r\n  }\r\n}`;\r\n\r\nexport interface UpdateTpPasswordResetMutationResult {\r\n  updateTpPasswordReset: {\r\n    tpPasswordReset: {\r\n      id: ID;\r\n    };\r\n  };\r\n}\r\nexport const UpdateTpPasswordResetMutation = gqlTyped<UpdateTpPasswordResetMutationResult>`\r\nmutation UpdateTpPasswordResetMutation($input: UpdateTpPasswordResetInput!) {\r\n  updateTpPasswordReset(input: $input) {\r\n    tpPasswordReset {\r\n      id\r\n    }\r\n  }\r\n}`;\r\n"]}
|