@lifeready/core 1.0.4 → 1.0.6
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 -62
- package/bundles/lifeready-core.umd.js +15445 -15445
- package/bundles/lifeready-core.umd.js.map +1 -1
- package/bundles/lifeready-core.umd.min.js +1 -1
- package/bundles/lifeready-core.umd.min.js.map +1 -1
- package/esm2015/lib/_common/ast.js +40 -40
- package/esm2015/lib/_common/deferred-promise.js +24 -24
- package/esm2015/lib/_common/exceptions.js +157 -157
- package/esm2015/lib/_common/queries.gql.js +190 -190
- package/esm2015/lib/_common/run-outside-angular.js +79 -79
- package/esm2015/lib/_common/types.js +1 -1
- package/esm2015/lib/_common/utils.js +44 -44
- package/esm2015/lib/api/contact-card.gql.js +79 -79
- package/esm2015/lib/api/contact-card.service.js +154 -154
- package/esm2015/lib/api/contact-card2.gql.js +60 -60
- package/esm2015/lib/api/contact-card2.service.js +103 -103
- package/esm2015/lib/api/file.service.js +74 -74
- package/esm2015/lib/api/item2.gql.js +110 -110
- package/esm2015/lib/api/item2.service.js +311 -311
- package/esm2015/lib/api/key-exchange.gql.js +188 -188
- package/esm2015/lib/api/key-exchange.service.js +442 -442
- package/esm2015/lib/api/key-exchange.types.js +18 -18
- package/esm2015/lib/api/key-exchange2.gql.js +171 -171
- package/esm2015/lib/api/key-exchange2.service.js +479 -479
- package/esm2015/lib/api/lock.gql.js +40 -40
- package/esm2015/lib/api/lock.service.js +64 -64
- package/esm2015/lib/api/lr-apollo.service.js +46 -46
- package/esm2015/lib/api/lr-graphql/index.js +6 -6
- package/esm2015/lib/api/lr-graphql/lr-graphql.service.js +155 -155
- package/esm2015/lib/api/lr-graphql/lr-merged-mutation.js +213 -213
- package/esm2015/lib/api/lr-graphql/lr-mutation-base.js +51 -51
- package/esm2015/lib/api/lr-graphql/lr-mutation.js +48 -48
- package/esm2015/lib/api/lr-graphql/lr.service.js +18 -18
- package/esm2015/lib/api/message.service.js +138 -138
- package/esm2015/lib/api/persist.service.js +181 -181
- package/esm2015/lib/api/query-processor/common-processors.service.js +93 -93
- package/esm2015/lib/api/query-processor/index.js +3 -3
- package/esm2015/lib/api/query-processor/query-processor.service.js +192 -192
- package/esm2015/lib/api/query-processor/tp-password-reset-processor.service.js +109 -109
- package/esm2015/lib/api/shared-contact-card.service.js +119 -119
- package/esm2015/lib/api/shared-contact-card2.gql.js +41 -41
- package/esm2015/lib/api/shared-contact-card2.service.js +117 -117
- package/esm2015/lib/api/time.service.js +146 -146
- package/esm2015/lib/api/types/graphql.types.js +7 -7
- package/esm2015/lib/api/types/index.js +3 -3
- package/esm2015/lib/api/types/lr-graphql.types.js +71 -71
- package/esm2015/lib/auth/auth.config.js +57 -57
- package/esm2015/lib/auth/auth.gql.js +48 -48
- package/esm2015/lib/auth/auth.types.js +27 -27
- package/esm2015/lib/auth/idle.service.js +168 -168
- package/esm2015/lib/auth/idle.types.js +7 -7
- package/esm2015/lib/auth/lbop.service.js +355 -355
- package/esm2015/lib/auth/life-ready-auth.service.js +500 -500
- package/esm2015/lib/auth/password.service.js +320 -320
- package/esm2015/lib/auth/register.service.js +172 -172
- package/esm2015/lib/auth/two-factor.service.js +74 -74
- package/esm2015/lib/category/category-meta.service.js +99 -99
- package/esm2015/lib/category/category.gql.js +406 -406
- package/esm2015/lib/category/category.service.js +390 -390
- package/esm2015/lib/category/category.types.js +29 -29
- package/esm2015/lib/cryptography/cryptography.types.js +11 -11
- package/esm2015/lib/cryptography/encryption.service.js +189 -189
- package/esm2015/lib/cryptography/key-factory.service.js +237 -237
- package/esm2015/lib/cryptography/key-graph.service.js +280 -280
- package/esm2015/lib/cryptography/key-meta.service.js +200 -200
- package/esm2015/lib/cryptography/key.service.js +124 -124
- package/esm2015/lib/cryptography/slip39.service.js +169 -169
- package/esm2015/lib/cryptography/web-crypto.service.js +29 -29
- package/esm2015/lib/life-ready.config.js +84 -84
- package/esm2015/lib/life-ready.module.js +74 -74
- package/esm2015/lib/plan/plan.gql.js +123 -123
- package/esm2015/lib/plan/plan.service.js +149 -149
- package/esm2015/lib/plan/plan.types.js +11 -11
- package/esm2015/lib/record/record-attachment.service.js +101 -101
- package/esm2015/lib/record/record.gql.js +179 -179
- package/esm2015/lib/record/record.service.js +206 -206
- package/esm2015/lib/record/record.types.js +15 -15
- package/esm2015/lib/record-type/record-type.service.js +75 -75
- package/esm2015/lib/record-type/record-type.types.js +28 -28
- package/esm2015/lib/scenario/approvals/scenario-approval.gql.js +105 -105
- package/esm2015/lib/scenario/approvals/scenario-approval.types.js +1 -1
- package/esm2015/lib/scenario/approvals/scenario-approver.service.js +300 -300
- package/esm2015/lib/scenario/claimants/scenario-claimant.gql.js +52 -52
- package/esm2015/lib/scenario/claimants/scenario-claimant.service.js +97 -97
- package/esm2015/lib/scenario/claimants/scenario-claimant.types.js +1 -1
- package/esm2015/lib/scenario/receivers/scenario-receiver.gql.js +150 -150
- package/esm2015/lib/scenario/receivers/scenario-receiver.service.js +229 -229
- package/esm2015/lib/scenario/receivers/scenario-receiver.types.js +1 -1
- package/esm2015/lib/scenario/scenario-setup.service.js +269 -269
- package/esm2015/lib/scenario/scenario.gql.js +368 -368
- package/esm2015/lib/scenario/scenario.service.js +611 -611
- package/esm2015/lib/scenario/scenario.types.js +64 -64
- package/esm2015/lib/search/search.gql.js +62 -62
- package/esm2015/lib/search/search.service.js +156 -156
- package/esm2015/lib/search/search.types.js +6 -6
- package/esm2015/lib/trusted-parties/tp-password-reset-request.service.js +112 -112
- package/esm2015/lib/trusted-parties/tp-password-reset-user.service.js +129 -129
- package/esm2015/lib/trusted-parties/tp-password-reset.constants.js +4 -4
- package/esm2015/lib/trusted-parties/tp-password-reset.gql.js +232 -232
- package/esm2015/lib/trusted-parties/tp-password-reset.service.js +299 -299
- package/esm2015/lib/trusted-parties/trusted-party.gql.js +148 -148
- package/esm2015/lib/trusted-parties/trusted-party.service.js +326 -326
- package/esm2015/lib/trusted-parties/trusted-party.types.js +41 -41
- package/esm2015/lib/trusted-parties/trusted-party2.gql.js +87 -87
- package/esm2015/lib/trusted-parties/trusted-party2.service.js +215 -215
- package/esm2015/lib/users/profile-details.service.js +214 -214
- package/esm2015/lib/users/profile.gql.js +97 -97
- package/esm2015/lib/users/profile.service.js +169 -169
- package/esm2015/lib/users/profile.types.js +34 -34
- package/esm2015/lib/users/user.gql.js +60 -60
- package/esm2015/lib/users/user.service.js +79 -79
- package/esm2015/lib/users/user.types.js +5 -5
- package/esm2015/lifeready-core.js +10 -10
- package/esm2015/public-api.js +81 -81
- package/fesm2015/lifeready-core.js +13088 -13088
- package/fesm2015/lifeready-core.js.map +1 -1
- package/lib/_common/ast.d.ts +11 -11
- package/lib/_common/deferred-promise.d.ts +12 -12
- package/lib/_common/exceptions.d.ts +109 -109
- package/lib/_common/queries.gql.d.ts +10 -10
- package/lib/_common/run-outside-angular.d.ts +14 -14
- package/lib/_common/types.d.ts +10 -10
- package/lib/_common/utils.d.ts +3 -3
- package/lib/api/contact-card.gql.d.ts +7 -7
- package/lib/api/contact-card.service.d.ts +52 -52
- package/lib/api/contact-card2.gql.d.ts +34 -34
- package/lib/api/contact-card2.service.d.ts +49 -49
- package/lib/api/file.service.d.ts +18 -18
- package/lib/api/item2.gql.d.ts +96 -96
- package/lib/api/item2.service.d.ts +177 -177
- package/lib/api/key-exchange.gql.d.ts +9 -9
- package/lib/api/key-exchange.service.d.ts +39 -39
- package/lib/api/key-exchange.types.d.ts +196 -196
- package/lib/api/key-exchange2.gql.d.ts +125 -125
- package/lib/api/key-exchange2.service.d.ts +187 -187
- package/lib/api/lock.gql.d.ts +27 -27
- package/lib/api/lock.service.d.ts +25 -25
- package/lib/api/lr-apollo.service.d.ts +15 -15
- package/lib/api/lr-graphql/index.d.ts +5 -5
- package/lib/api/lr-graphql/lr-graphql.service.d.ts +60 -60
- package/lib/api/lr-graphql/lr-merged-mutation.d.ts +27 -27
- package/lib/api/lr-graphql/lr-mutation-base.d.ts +28 -28
- package/lib/api/lr-graphql/lr-mutation.d.ts +8 -8
- package/lib/api/lr-graphql/lr.service.d.ts +9 -9
- package/lib/api/message.service.d.ts +58 -58
- package/lib/api/persist.service.d.ts +31 -31
- package/lib/api/query-processor/common-processors.service.d.ts +36 -36
- package/lib/api/query-processor/index.d.ts +2 -2
- package/lib/api/query-processor/query-processor.service.d.ts +18 -18
- package/lib/api/query-processor/tp-password-reset-processor.service.d.ts +15 -15
- package/lib/api/shared-contact-card.service.d.ts +33 -33
- package/lib/api/shared-contact-card2.gql.d.ts +36 -36
- package/lib/api/shared-contact-card2.service.d.ts +45 -45
- package/lib/api/time.service.d.ts +16 -16
- package/lib/api/types/graphql.types.d.ts +29 -29
- package/lib/api/types/index.d.ts +2 -2
- package/lib/api/types/lr-graphql.types.d.ts +393 -385
- package/lib/auth/auth.config.d.ts +5 -5
- package/lib/auth/auth.gql.d.ts +15 -15
- package/lib/auth/auth.types.d.ts +66 -66
- package/lib/auth/idle.service.d.ts +40 -40
- package/lib/auth/idle.types.d.ts +10 -10
- package/lib/auth/lbop.service.d.ts +91 -91
- package/lib/auth/life-ready-auth.service.d.ts +59 -59
- package/lib/auth/password.service.d.ts +78 -78
- package/lib/auth/register.service.d.ts +25 -25
- package/lib/auth/two-factor.service.d.ts +15 -15
- package/lib/category/category-meta.service.d.ts +23 -23
- package/lib/category/category.gql.d.ts +45 -45
- package/lib/category/category.service.d.ts +67 -67
- package/lib/category/category.types.d.ts +79 -79
- package/lib/cryptography/cryptography.types.d.ts +83 -83
- package/lib/cryptography/encryption.service.d.ts +41 -41
- package/lib/cryptography/key-factory.service.d.ts +38 -38
- package/lib/cryptography/key-graph.service.d.ts +33 -33
- package/lib/cryptography/key-meta.service.d.ts +44 -44
- package/lib/cryptography/key.service.d.ts +36 -36
- package/lib/cryptography/slip39.service.d.ts +43 -43
- package/lib/cryptography/web-crypto.service.d.ts +5 -5
- package/lib/life-ready.config.d.ts +14 -14
- package/lib/life-ready.module.d.ts +5 -5
- package/lib/plan/plan.gql.d.ts +11 -11
- package/lib/plan/plan.service.d.ts +33 -33
- package/lib/plan/plan.types.d.ts +31 -31
- package/lib/record/record-attachment.service.d.ts +16 -16
- package/lib/record/record.gql.d.ts +14 -14
- package/lib/record/record.service.d.ts +25 -25
- package/lib/record/record.types.d.ts +57 -57
- package/lib/record-type/record-type.service.d.ts +11 -11
- package/lib/record-type/record-type.types.d.ts +50 -50
- package/lib/scenario/approvals/scenario-approval.gql.d.ts +7 -7
- package/lib/scenario/approvals/scenario-approval.types.d.ts +63 -63
- package/lib/scenario/approvals/scenario-approver.service.d.ts +32 -32
- package/lib/scenario/claimants/scenario-claimant.gql.d.ts +5 -5
- package/lib/scenario/claimants/scenario-claimant.service.d.ts +17 -17
- package/lib/scenario/claimants/scenario-claimant.types.d.ts +18 -18
- package/lib/scenario/receivers/scenario-receiver.gql.d.ts +8 -8
- package/lib/scenario/receivers/scenario-receiver.service.d.ts +30 -30
- package/lib/scenario/receivers/scenario-receiver.types.d.ts +54 -54
- package/lib/scenario/scenario-setup.service.d.ts +22 -22
- package/lib/scenario/scenario.gql.d.ts +34 -34
- package/lib/scenario/scenario.service.d.ts +58 -58
- package/lib/scenario/scenario.types.d.ts +217 -217
- package/lib/search/search.gql.d.ts +1 -1
- package/lib/search/search.service.d.ts +25 -25
- package/lib/search/search.types.d.ts +20 -20
- package/lib/trusted-parties/tp-password-reset-request.service.d.ts +20 -20
- package/lib/trusted-parties/tp-password-reset-user.service.d.ts +35 -35
- package/lib/trusted-parties/tp-password-reset.constants.d.ts +3 -3
- package/lib/trusted-parties/tp-password-reset.gql.d.ts +218 -218
- package/lib/trusted-parties/tp-password-reset.service.d.ts +130 -130
- package/lib/trusted-parties/trusted-party.gql.d.ts +9 -9
- package/lib/trusted-parties/trusted-party.service.d.ts +44 -44
- package/lib/trusted-parties/trusted-party.types.d.ts +102 -102
- package/lib/trusted-parties/trusted-party2.gql.d.ts +79 -79
- package/lib/trusted-parties/trusted-party2.service.d.ts +114 -114
- package/lib/users/profile-details.service.d.ts +21 -21
- package/lib/users/profile.gql.d.ts +11 -11
- package/lib/users/profile.service.d.ts +35 -35
- package/lib/users/profile.types.d.ts +96 -96
- package/lib/users/user.gql.d.ts +9 -9
- package/lib/users/user.service.d.ts +12 -12
- package/lib/users/user.types.d.ts +23 -23
- package/lifeready-core.d.ts +9 -9
- package/package.json +1 -1
- package/public-api.d.ts +77 -77
|
@@ -1,112 +1,112 @@
|
|
|
1
|
-
import { __awaiter, __decorate } from "tslib";
|
|
2
|
-
import { Injectable, Injector, NgZone } from '@angular/core';
|
|
3
|
-
import { JWK } from 'node-jose';
|
|
4
|
-
import { LrMergedMutation, LrMutation, LrService, } from '../api/lr-graphql';
|
|
5
|
-
import { TpAssemblyState, TpClaimApproverState } from '../api/types';
|
|
6
|
-
import { EncryptionService } from '../cryptography/encryption.service';
|
|
7
|
-
import { LrBadStateException } from '../_common/exceptions';
|
|
8
|
-
import { RunOutsideAngular } from '../_common/run-outside-angular';
|
|
9
|
-
import { ApproveTpPasswordResetRequestMutation, RejectTpPasswordResetRequestMutation, SharedTpPasswordResetQuery, SharedTpPasswordResetsQuery, } from './tp-password-reset.gql';
|
|
10
|
-
import * as i0 from "@angular/core";
|
|
11
|
-
import * as i1 from "../cryptography/encryption.service";
|
|
12
|
-
let TpPasswordResetRequestService = class TpPasswordResetRequestService extends LrService {
|
|
13
|
-
constructor(ngZone, injector, encryptionService) {
|
|
14
|
-
super(injector);
|
|
15
|
-
this.ngZone = ngZone;
|
|
16
|
-
this.injector = injector;
|
|
17
|
-
this.encryptionService = encryptionService;
|
|
18
|
-
}
|
|
19
|
-
getSharedResets() {
|
|
20
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
21
|
-
return (yield this.query({
|
|
22
|
-
query: SharedTpPasswordResetsQuery,
|
|
23
|
-
})).sharedTpPasswordResets;
|
|
24
|
-
});
|
|
25
|
-
}
|
|
26
|
-
getSharedReset(id) {
|
|
27
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
28
|
-
return (yield this.query({
|
|
29
|
-
query: SharedTpPasswordResetQuery,
|
|
30
|
-
variables: {
|
|
31
|
-
id,
|
|
32
|
-
},
|
|
33
|
-
})).sharedTpPasswordReset;
|
|
34
|
-
});
|
|
35
|
-
}
|
|
36
|
-
activeRequestOrRaise(sharedReset) {
|
|
37
|
-
const state = sharedReset.sharedRequest.claim.state;
|
|
38
|
-
if (state !== TpAssemblyState.CLAIMED) {
|
|
39
|
-
throw new LrBadStateException(`Claim is already in ${state} state.`);
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
rejectRequest(sharedResetId) {
|
|
43
|
-
return this.mutate(this.rejectRequestMutation(sharedResetId));
|
|
44
|
-
}
|
|
45
|
-
rejectRequestMutation(sharedResetId) {
|
|
46
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
47
|
-
const sharedReset = yield this.getSharedReset(sharedResetId);
|
|
48
|
-
this.activeRequestOrRaise(sharedReset);
|
|
49
|
-
return LrMergedMutation.create(sharedReset.sharedRequest.claim.asClaimApprovers.edges
|
|
50
|
-
.filter((edge) => edge.node.state === TpClaimApproverState.CLAIMED)
|
|
51
|
-
.map((edge) => new LrMutation({
|
|
52
|
-
mutation: RejectTpPasswordResetRequestMutation,
|
|
53
|
-
variables: { input: { claimApproverId: edge.node.id } },
|
|
54
|
-
})));
|
|
55
|
-
});
|
|
56
|
-
}
|
|
57
|
-
// ?? TODO The return from this should not be any.
|
|
58
|
-
approveRequest(sharedResetId, pbkFingerPrint) {
|
|
59
|
-
return this.mutate(this.approveRequestMutation(sharedResetId, pbkFingerPrint));
|
|
60
|
-
}
|
|
61
|
-
approveRequestMutation(sharedResetId, pbkFingerPrint) {
|
|
62
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
63
|
-
const sharedReset = yield this.getSharedReset(sharedResetId);
|
|
64
|
-
this.activeRequestOrRaise(sharedReset);
|
|
65
|
-
const pbk = yield JWK.asKey(JSON.parse(sharedReset.sharedRequest.pxk.pbk));
|
|
66
|
-
console.log(pbk.toJSON());
|
|
67
|
-
// TODO <AZ> Verify pbk against pbkFingerPrint
|
|
68
|
-
const claimApprovers = sharedReset.sharedRequest.claim.asClaimApprovers.edges.filter((edge) => edge.node.state === TpClaimApproverState.CLAIMED);
|
|
69
|
-
// A single approver may belong to multiple sub-assemblies. We approve them all here in a single
|
|
70
|
-
// transaction.
|
|
71
|
-
return LrMergedMutation.create(yield Promise.all(claimApprovers.map((approverEdge) => __awaiter(this, void 0, void 0, function* () {
|
|
72
|
-
const ca = approverEdge.node;
|
|
73
|
-
const input = {
|
|
74
|
-
claimApproverId: ca.id,
|
|
75
|
-
receiverApprovals: yield Promise.all(ca.receiverApprovals.edges.map((receiverEdge) => __awaiter(this, void 0, void 0, function* () {
|
|
76
|
-
const ra = receiverEdge.node;
|
|
77
|
-
return {
|
|
78
|
-
receiverApprovalId: ra.id,
|
|
79
|
-
receiverCipher: '',
|
|
80
|
-
receiverCipherPartialAssemblyKey: yield this.encryptionService.encryptToString(pbk, ca.sharedCipherPartialAssemblyKeyClearJson),
|
|
81
|
-
};
|
|
82
|
-
}))),
|
|
83
|
-
};
|
|
84
|
-
console.log(input);
|
|
85
|
-
return new LrMutation({
|
|
86
|
-
mutation: ApproveTpPasswordResetRequestMutation,
|
|
87
|
-
variables: {
|
|
88
|
-
input,
|
|
89
|
-
},
|
|
90
|
-
});
|
|
91
|
-
}))));
|
|
92
|
-
});
|
|
93
|
-
}
|
|
94
|
-
};
|
|
95
|
-
TpPasswordResetRequestService.ɵprov = i0.ɵɵdefineInjectable({ factory: function TpPasswordResetRequestService_Factory() { return new TpPasswordResetRequestService(i0.ɵɵinject(i0.NgZone), i0.ɵɵinject(i0.INJECTOR), i0.ɵɵinject(i1.EncryptionService)); }, token: TpPasswordResetRequestService, providedIn: "root" });
|
|
96
|
-
TpPasswordResetRequestService.decorators = [
|
|
97
|
-
{ type: Injectable, args: [{
|
|
98
|
-
providedIn: 'root',
|
|
99
|
-
},] }
|
|
100
|
-
];
|
|
101
|
-
TpPasswordResetRequestService.ctorParameters = () => [
|
|
102
|
-
{ type: NgZone },
|
|
103
|
-
{ type: Injector },
|
|
104
|
-
{ type: EncryptionService }
|
|
105
|
-
];
|
|
106
|
-
TpPasswordResetRequestService = __decorate([
|
|
107
|
-
RunOutsideAngular({
|
|
108
|
-
ngZoneName: 'ngZone',
|
|
109
|
-
})
|
|
110
|
-
], TpPasswordResetRequestService);
|
|
111
|
-
export { TpPasswordResetRequestService };
|
|
112
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tp-password-reset-request.service.js","sourceRoot":"C:/Projects/newrepo/kc-client/projects/core/src/","sources":["lib/trusted-parties/tp-password-reset-request.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Injector, NgZone } from '@angular/core';\r\nimport { JWK } from 'node-jose';\r\nimport {\r\n  LrGraphQLService,\r\n  LrMergedMutation,\r\n  LrMutation,\r\n  LrMutationBase,\r\n  LrService,\r\n} from '../api/lr-graphql';\r\nimport { TpAssemblyState, TpClaimApproverState } from '../api/types';\r\nimport { EncryptionService } from '../cryptography/encryption.service';\r\nimport { LrBadStateException } from '../_common/exceptions';\r\nimport { RunOutsideAngular } from '../_common/run-outside-angular';\r\nimport {\r\n  ApproveTpPasswordResetRequestMutation,\r\n  RejectTpPasswordResetRequestMutation,\r\n  SharedTpPasswordResetQuery,\r\n  SharedTpPasswordResetsQuery,\r\n} from './tp-password-reset.gql';\r\n\r\n@RunOutsideAngular({\r\n  ngZoneName: 'ngZone',\r\n})\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class TpPasswordResetRequestService extends LrService {\r\n  constructor(\r\n    private ngZone: NgZone,\r\n    private injector: Injector,\r\n    private encryptionService: EncryptionService\r\n  ) {\r\n    super(injector);\r\n  }\r\n\r\n  async getSharedResets() {\r\n    return (\r\n      await this.query({\r\n        query: SharedTpPasswordResetsQuery,\r\n      })\r\n    ).sharedTpPasswordResets;\r\n  }\r\n\r\n  async getSharedReset(id) {\r\n    return (\r\n      await this.query({\r\n        query: SharedTpPasswordResetQuery,\r\n        variables: {\r\n          id,\r\n        },\r\n      })\r\n    ).sharedTpPasswordReset;\r\n  }\r\n\r\n  private activeRequestOrRaise(sharedReset): void {\r\n    const state = sharedReset.sharedRequest.claim.state;\r\n    if (state !== TpAssemblyState.CLAIMED) {\r\n      throw new LrBadStateException(`Claim is already in ${state} state.`);\r\n    }\r\n  }\r\n\r\n  rejectRequest(sharedResetId: string) {\r\n    return this.mutate(this.rejectRequestMutation(sharedResetId));\r\n  }\r\n\r\n  async rejectRequestMutation(sharedResetId: string) {\r\n    const sharedReset = await this.getSharedReset(sharedResetId);\r\n\r\n    this.activeRequestOrRaise(sharedReset);\r\n\r\n    return LrMergedMutation.create(\r\n      sharedReset.sharedRequest.claim.asClaimApprovers.edges\r\n        .filter((edge) => edge.node.state === TpClaimApproverState.CLAIMED)\r\n        .map(\r\n          (edge) =>\r\n            new LrMutation({\r\n              mutation: RejectTpPasswordResetRequestMutation,\r\n              variables: { input: { claimApproverId: edge.node.id } },\r\n            })\r\n        )\r\n    );\r\n  }\r\n\r\n  // ?? TODO The return from this should not be any.\r\n  approveRequest(sharedResetId: string, pbkFingerPrint?: string) {\r\n    return this.mutate(\r\n      this.approveRequestMutation(sharedResetId, pbkFingerPrint)\r\n    );\r\n  }\r\n\r\n  async approveRequestMutation(sharedResetId: string, pbkFingerPrint?: string) {\r\n    const sharedReset = await this.getSharedReset(sharedResetId);\r\n\r\n    this.activeRequestOrRaise(sharedReset);\r\n\r\n    const pbk = await JWK.asKey(JSON.parse(sharedReset.sharedRequest.pxk.pbk));\r\n    console.log(pbk.toJSON());\r\n\r\n    // TODO <AZ> Verify pbk against pbkFingerPrint\r\n\r\n    const claimApprovers = sharedReset.sharedRequest.claim.asClaimApprovers.edges.filter(\r\n      (edge) => edge.node.state === TpClaimApproverState.CLAIMED\r\n    );\r\n\r\n    // A single approver may belong to multiple sub-assemblies. We approve them all here in a single\r\n    // transaction.\r\n    return LrMergedMutation.create(\r\n      await Promise.all(\r\n        claimApprovers.map(async (approverEdge) => {\r\n          const ca = approverEdge.node;\r\n          const input = {\r\n            claimApproverId: ca.id,\r\n            receiverApprovals: await Promise.all(\r\n              ca.receiverApprovals.edges.map(async (receiverEdge) => {\r\n                const ra = receiverEdge.node;\r\n                return {\r\n                  receiverApprovalId: ra.id,\r\n                  receiverCipher: '',\r\n                  receiverCipherPartialAssemblyKey: await this.encryptionService.encryptToString(\r\n                    pbk,\r\n                    ca.sharedCipherPartialAssemblyKeyClearJson\r\n                  ),\r\n                };\r\n              })\r\n            ),\r\n          };\r\n\r\n          console.log(input);\r\n\r\n          return new LrMutation({\r\n            mutation: ApproveTpPasswordResetRequestMutation,\r\n            variables: {\r\n              input,\r\n            },\r\n          });\r\n        })\r\n      )\r\n    );\r\n  }\r\n}\r\n"]}
|
|
1
|
+
import { __awaiter, __decorate } from "tslib";
|
|
2
|
+
import { Injectable, Injector, NgZone } from '@angular/core';
|
|
3
|
+
import { JWK } from 'node-jose';
|
|
4
|
+
import { LrMergedMutation, LrMutation, LrService, } from '../api/lr-graphql';
|
|
5
|
+
import { TpAssemblyState, TpClaimApproverState } from '../api/types';
|
|
6
|
+
import { EncryptionService } from '../cryptography/encryption.service';
|
|
7
|
+
import { LrBadStateException } from '../_common/exceptions';
|
|
8
|
+
import { RunOutsideAngular } from '../_common/run-outside-angular';
|
|
9
|
+
import { ApproveTpPasswordResetRequestMutation, RejectTpPasswordResetRequestMutation, SharedTpPasswordResetQuery, SharedTpPasswordResetsQuery, } from './tp-password-reset.gql';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
import * as i1 from "../cryptography/encryption.service";
|
|
12
|
+
let TpPasswordResetRequestService = class TpPasswordResetRequestService extends LrService {
|
|
13
|
+
constructor(ngZone, injector, encryptionService) {
|
|
14
|
+
super(injector);
|
|
15
|
+
this.ngZone = ngZone;
|
|
16
|
+
this.injector = injector;
|
|
17
|
+
this.encryptionService = encryptionService;
|
|
18
|
+
}
|
|
19
|
+
getSharedResets() {
|
|
20
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
21
|
+
return (yield this.query({
|
|
22
|
+
query: SharedTpPasswordResetsQuery,
|
|
23
|
+
})).sharedTpPasswordResets;
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
getSharedReset(id) {
|
|
27
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
28
|
+
return (yield this.query({
|
|
29
|
+
query: SharedTpPasswordResetQuery,
|
|
30
|
+
variables: {
|
|
31
|
+
id,
|
|
32
|
+
},
|
|
33
|
+
})).sharedTpPasswordReset;
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
activeRequestOrRaise(sharedReset) {
|
|
37
|
+
const state = sharedReset.sharedRequest.claim.state;
|
|
38
|
+
if (state !== TpAssemblyState.CLAIMED) {
|
|
39
|
+
throw new LrBadStateException(`Claim is already in ${state} state.`);
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
rejectRequest(sharedResetId) {
|
|
43
|
+
return this.mutate(this.rejectRequestMutation(sharedResetId));
|
|
44
|
+
}
|
|
45
|
+
rejectRequestMutation(sharedResetId) {
|
|
46
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
47
|
+
const sharedReset = yield this.getSharedReset(sharedResetId);
|
|
48
|
+
this.activeRequestOrRaise(sharedReset);
|
|
49
|
+
return LrMergedMutation.create(sharedReset.sharedRequest.claim.asClaimApprovers.edges
|
|
50
|
+
.filter((edge) => edge.node.state === TpClaimApproverState.CLAIMED)
|
|
51
|
+
.map((edge) => new LrMutation({
|
|
52
|
+
mutation: RejectTpPasswordResetRequestMutation,
|
|
53
|
+
variables: { input: { claimApproverId: edge.node.id } },
|
|
54
|
+
})));
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
// ?? TODO The return from this should not be any.
|
|
58
|
+
approveRequest(sharedResetId, pbkFingerPrint) {
|
|
59
|
+
return this.mutate(this.approveRequestMutation(sharedResetId, pbkFingerPrint));
|
|
60
|
+
}
|
|
61
|
+
approveRequestMutation(sharedResetId, pbkFingerPrint) {
|
|
62
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
63
|
+
const sharedReset = yield this.getSharedReset(sharedResetId);
|
|
64
|
+
this.activeRequestOrRaise(sharedReset);
|
|
65
|
+
const pbk = yield JWK.asKey(JSON.parse(sharedReset.sharedRequest.pxk.pbk));
|
|
66
|
+
console.log(pbk.toJSON());
|
|
67
|
+
// TODO <AZ> Verify pbk against pbkFingerPrint
|
|
68
|
+
const claimApprovers = sharedReset.sharedRequest.claim.asClaimApprovers.edges.filter((edge) => edge.node.state === TpClaimApproverState.CLAIMED);
|
|
69
|
+
// A single approver may belong to multiple sub-assemblies. We approve them all here in a single
|
|
70
|
+
// transaction.
|
|
71
|
+
return LrMergedMutation.create(yield Promise.all(claimApprovers.map((approverEdge) => __awaiter(this, void 0, void 0, function* () {
|
|
72
|
+
const ca = approverEdge.node;
|
|
73
|
+
const input = {
|
|
74
|
+
claimApproverId: ca.id,
|
|
75
|
+
receiverApprovals: yield Promise.all(ca.receiverApprovals.edges.map((receiverEdge) => __awaiter(this, void 0, void 0, function* () {
|
|
76
|
+
const ra = receiverEdge.node;
|
|
77
|
+
return {
|
|
78
|
+
receiverApprovalId: ra.id,
|
|
79
|
+
receiverCipher: '',
|
|
80
|
+
receiverCipherPartialAssemblyKey: yield this.encryptionService.encryptToString(pbk, ca.sharedCipherPartialAssemblyKeyClearJson),
|
|
81
|
+
};
|
|
82
|
+
}))),
|
|
83
|
+
};
|
|
84
|
+
console.log(input);
|
|
85
|
+
return new LrMutation({
|
|
86
|
+
mutation: ApproveTpPasswordResetRequestMutation,
|
|
87
|
+
variables: {
|
|
88
|
+
input,
|
|
89
|
+
},
|
|
90
|
+
});
|
|
91
|
+
}))));
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
};
|
|
95
|
+
TpPasswordResetRequestService.ɵprov = i0.ɵɵdefineInjectable({ factory: function TpPasswordResetRequestService_Factory() { return new TpPasswordResetRequestService(i0.ɵɵinject(i0.NgZone), i0.ɵɵinject(i0.INJECTOR), i0.ɵɵinject(i1.EncryptionService)); }, token: TpPasswordResetRequestService, providedIn: "root" });
|
|
96
|
+
TpPasswordResetRequestService.decorators = [
|
|
97
|
+
{ type: Injectable, args: [{
|
|
98
|
+
providedIn: 'root',
|
|
99
|
+
},] }
|
|
100
|
+
];
|
|
101
|
+
TpPasswordResetRequestService.ctorParameters = () => [
|
|
102
|
+
{ type: NgZone },
|
|
103
|
+
{ type: Injector },
|
|
104
|
+
{ type: EncryptionService }
|
|
105
|
+
];
|
|
106
|
+
TpPasswordResetRequestService = __decorate([
|
|
107
|
+
RunOutsideAngular({
|
|
108
|
+
ngZoneName: 'ngZone',
|
|
109
|
+
})
|
|
110
|
+
], TpPasswordResetRequestService);
|
|
111
|
+
export { TpPasswordResetRequestService };
|
|
112
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tp-password-reset-request.service.js","sourceRoot":"/opt/atlassian/pipelines/agent/build/projects/core/src/","sources":["lib/trusted-parties/tp-password-reset-request.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Injector, NgZone } from '@angular/core';\nimport { JWK } from 'node-jose';\nimport {\n  LrGraphQLService,\n  LrMergedMutation,\n  LrMutation,\n  LrMutationBase,\n  LrService,\n} from '../api/lr-graphql';\nimport { TpAssemblyState, TpClaimApproverState } from '../api/types';\nimport { EncryptionService } from '../cryptography/encryption.service';\nimport { LrBadStateException } from '../_common/exceptions';\nimport { RunOutsideAngular } from '../_common/run-outside-angular';\nimport {\n  ApproveTpPasswordResetRequestMutation,\n  RejectTpPasswordResetRequestMutation,\n  SharedTpPasswordResetQuery,\n  SharedTpPasswordResetsQuery,\n} from './tp-password-reset.gql';\n\n@RunOutsideAngular({\n  ngZoneName: 'ngZone',\n})\n@Injectable({\n  providedIn: 'root',\n})\nexport class TpPasswordResetRequestService extends LrService {\n  constructor(\n    private ngZone: NgZone,\n    private injector: Injector,\n    private encryptionService: EncryptionService\n  ) {\n    super(injector);\n  }\n\n  async getSharedResets() {\n    return (\n      await this.query({\n        query: SharedTpPasswordResetsQuery,\n      })\n    ).sharedTpPasswordResets;\n  }\n\n  async getSharedReset(id) {\n    return (\n      await this.query({\n        query: SharedTpPasswordResetQuery,\n        variables: {\n          id,\n        },\n      })\n    ).sharedTpPasswordReset;\n  }\n\n  private activeRequestOrRaise(sharedReset): void {\n    const state = sharedReset.sharedRequest.claim.state;\n    if (state !== TpAssemblyState.CLAIMED) {\n      throw new LrBadStateException(`Claim is already in ${state} state.`);\n    }\n  }\n\n  rejectRequest(sharedResetId: string) {\n    return this.mutate(this.rejectRequestMutation(sharedResetId));\n  }\n\n  async rejectRequestMutation(sharedResetId: string) {\n    const sharedReset = await this.getSharedReset(sharedResetId);\n\n    this.activeRequestOrRaise(sharedReset);\n\n    return LrMergedMutation.create(\n      sharedReset.sharedRequest.claim.asClaimApprovers.edges\n        .filter((edge) => edge.node.state === TpClaimApproverState.CLAIMED)\n        .map(\n          (edge) =>\n            new LrMutation({\n              mutation: RejectTpPasswordResetRequestMutation,\n              variables: { input: { claimApproverId: edge.node.id } },\n            })\n        )\n    );\n  }\n\n  // ?? TODO The return from this should not be any.\n  approveRequest(sharedResetId: string, pbkFingerPrint?: string) {\n    return this.mutate(\n      this.approveRequestMutation(sharedResetId, pbkFingerPrint)\n    );\n  }\n\n  async approveRequestMutation(sharedResetId: string, pbkFingerPrint?: string) {\n    const sharedReset = await this.getSharedReset(sharedResetId);\n\n    this.activeRequestOrRaise(sharedReset);\n\n    const pbk = await JWK.asKey(JSON.parse(sharedReset.sharedRequest.pxk.pbk));\n    console.log(pbk.toJSON());\n\n    // TODO <AZ> Verify pbk against pbkFingerPrint\n\n    const claimApprovers = sharedReset.sharedRequest.claim.asClaimApprovers.edges.filter(\n      (edge) => edge.node.state === TpClaimApproverState.CLAIMED\n    );\n\n    // A single approver may belong to multiple sub-assemblies. We approve them all here in a single\n    // transaction.\n    return LrMergedMutation.create(\n      await Promise.all(\n        claimApprovers.map(async (approverEdge) => {\n          const ca = approverEdge.node;\n          const input = {\n            claimApproverId: ca.id,\n            receiverApprovals: await Promise.all(\n              ca.receiverApprovals.edges.map(async (receiverEdge) => {\n                const ra = receiverEdge.node;\n                return {\n                  receiverApprovalId: ra.id,\n                  receiverCipher: '',\n                  receiverCipherPartialAssemblyKey: await this.encryptionService.encryptToString(\n                    pbk,\n                    ca.sharedCipherPartialAssemblyKeyClearJson\n                  ),\n                };\n              })\n            ),\n          };\n\n          console.log(input);\n\n          return new LrMutation({\n            mutation: ApproveTpPasswordResetRequestMutation,\n            variables: {\n              input,\n            },\n          });\n        })\n      )\n    );\n  }\n}\n"]}
|
|
@@ -1,129 +1,129 @@
|
|
|
1
|
-
import { __awaiter, __decorate } from "tslib";
|
|
2
|
-
import { Inject, Injectable, Injector, NgZone } from '@angular/core';
|
|
3
|
-
import { EncryptionService } from '../cryptography/encryption.service';
|
|
4
|
-
import { KeyGraphService } from '../cryptography/key-graph.service';
|
|
5
|
-
import { LR_CONFIG } from '../life-ready.config';
|
|
6
|
-
import * as slip from '../cryptography/slip39.service';
|
|
7
|
-
import { PasswordService } from '../auth/password.service';
|
|
8
|
-
import { HttpClient } from '@angular/common/http';
|
|
9
|
-
import { AuthClass } from '@aws-amplify/auth/lib-esm/Auth';
|
|
10
|
-
import { LifeReadyAuthService } from '../auth/life-ready-auth.service';
|
|
11
|
-
import { KeyFactoryService } from '../cryptography/key-factory.service';
|
|
12
|
-
import { LrService } from '../api/lr-graphql';
|
|
13
|
-
import { RunOutsideAngular } from '../_common/run-outside-angular';
|
|
14
|
-
import * as i0 from "@angular/core";
|
|
15
|
-
import * as i1 from "../life-ready.config";
|
|
16
|
-
import * as i2 from "../cryptography/key-factory.service";
|
|
17
|
-
import * as i3 from "../cryptography/encryption.service";
|
|
18
|
-
import * as i4 from "../cryptography/key-graph.service";
|
|
19
|
-
import * as i5 from "../cryptography/slip39.service";
|
|
20
|
-
import * as i6 from "../auth/password.service";
|
|
21
|
-
import * as i7 from "@angular/common/http";
|
|
22
|
-
import * as i8 from "@aws-amplify/auth/lib-esm/Auth";
|
|
23
|
-
import * as i9 from "../auth/life-ready-auth.service";
|
|
24
|
-
let TpPasswordResetUserService = class TpPasswordResetUserService extends LrService {
|
|
25
|
-
constructor(ngZone, injector, config, keyFactory, encryptionService, keyGraphService, slip39Service, passwordService, http, auth, lrAuth) {
|
|
26
|
-
super(injector);
|
|
27
|
-
this.ngZone = ngZone;
|
|
28
|
-
this.injector = injector;
|
|
29
|
-
this.config = config;
|
|
30
|
-
this.keyFactory = keyFactory;
|
|
31
|
-
this.encryptionService = encryptionService;
|
|
32
|
-
this.keyGraphService = keyGraphService;
|
|
33
|
-
this.slip39Service = slip39Service;
|
|
34
|
-
this.passwordService = passwordService;
|
|
35
|
-
this.http = http;
|
|
36
|
-
this.auth = auth;
|
|
37
|
-
this.lrAuth = lrAuth;
|
|
38
|
-
}
|
|
39
|
-
verifyEmailContact(email) {
|
|
40
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
41
|
-
const params = {
|
|
42
|
-
email,
|
|
43
|
-
};
|
|
44
|
-
return this.http
|
|
45
|
-
.post(`${this.config.authUrl}tp/password-reset/verify-contact/`, params)
|
|
46
|
-
.toPromise();
|
|
47
|
-
});
|
|
48
|
-
}
|
|
49
|
-
verifyContactRespond(claimId, claimCode) {
|
|
50
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
51
|
-
const { token } = yield this.http
|
|
52
|
-
.post(`${this.config.authUrl}cove/respond/`, {
|
|
53
|
-
claim_id: claimId,
|
|
54
|
-
v_code: claimCode,
|
|
55
|
-
})
|
|
56
|
-
.toPromise();
|
|
57
|
-
return token;
|
|
58
|
-
});
|
|
59
|
-
}
|
|
60
|
-
requestReset(password, claimId, claimToken) {
|
|
61
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
62
|
-
// Generate the key materials
|
|
63
|
-
const passKeyBundle = yield this.passwordService.createPassKeyBundle(password);
|
|
64
|
-
const masterKey = yield this.keyFactory.createKey();
|
|
65
|
-
const wrappedMasterKey = yield this.encryptionService.encrypt(passKeyBundle.passKey, masterKey.toJSON(true));
|
|
66
|
-
// Ephemeral PKC key
|
|
67
|
-
const prk = yield this.keyFactory.createPkcKey();
|
|
68
|
-
const masterKeyWrappedPrk = yield this.encryptionService.encrypt(masterKey, prk.toJSON(true));
|
|
69
|
-
// API call to setup reset request
|
|
70
|
-
const requestResetResult = yield this.http
|
|
71
|
-
.post(`${this.config.authUrl}tp/password-reset/request/`, {
|
|
72
|
-
claimId,
|
|
73
|
-
claimToken,
|
|
74
|
-
pass_key_params: passKeyBundle.passKeyParams,
|
|
75
|
-
pass_idp_params: passKeyBundle.passIdpParams,
|
|
76
|
-
pass_idp_verifier_pbk: passKeyBundle.passIdpVerifier.toJSON(),
|
|
77
|
-
wrapped_pass_idp_verifier_prk: passKeyBundle.wrappedPassIdpVerifierPrk,
|
|
78
|
-
wrapped_master_key: wrappedMasterKey,
|
|
79
|
-
pbk: prk.toJSON(),
|
|
80
|
-
master_key_wrapped_prk: masterKeyWrappedPrk,
|
|
81
|
-
})
|
|
82
|
-
.toPromise();
|
|
83
|
-
console.log(requestResetResult);
|
|
84
|
-
console.log('Using new password: ', this.passwordService.getPassIdpString(passKeyBundle.passIdp));
|
|
85
|
-
// API call to create user on cognito
|
|
86
|
-
const signUpResult = yield this.auth.signUp({
|
|
87
|
-
username: requestResetResult.reset_username,
|
|
88
|
-
password: this.passwordService.getPassIdpString(passKeyBundle.passIdp),
|
|
89
|
-
clientMetadata: {
|
|
90
|
-
tp_password_reset_request: JSON.stringify({
|
|
91
|
-
id: requestResetResult.id,
|
|
92
|
-
associate_reset_user_token: requestResetResult.associate_reset_user_token,
|
|
93
|
-
}),
|
|
94
|
-
},
|
|
95
|
-
});
|
|
96
|
-
console.log('requestRest done: ', signUpResult);
|
|
97
|
-
return {
|
|
98
|
-
requestResetResult,
|
|
99
|
-
signUpResult,
|
|
100
|
-
};
|
|
101
|
-
});
|
|
102
|
-
}
|
|
103
|
-
};
|
|
104
|
-
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" });
|
|
105
|
-
TpPasswordResetUserService.decorators = [
|
|
106
|
-
{ type: Injectable, args: [{
|
|
107
|
-
providedIn: 'root',
|
|
108
|
-
},] }
|
|
109
|
-
];
|
|
110
|
-
TpPasswordResetUserService.ctorParameters = () => [
|
|
111
|
-
{ type: NgZone },
|
|
112
|
-
{ type: Injector },
|
|
113
|
-
{ type: undefined, decorators: [{ type: Inject, args: [LR_CONFIG,] }] },
|
|
114
|
-
{ type: KeyFactoryService },
|
|
115
|
-
{ type: EncryptionService },
|
|
116
|
-
{ type: KeyGraphService },
|
|
117
|
-
{ type: slip.Slip39Service },
|
|
118
|
-
{ type: PasswordService },
|
|
119
|
-
{ type: HttpClient },
|
|
120
|
-
{ type: AuthClass },
|
|
121
|
-
{ type: LifeReadyAuthService }
|
|
122
|
-
];
|
|
123
|
-
TpPasswordResetUserService = __decorate([
|
|
124
|
-
RunOutsideAngular({
|
|
125
|
-
ngZoneName: 'ngZone',
|
|
126
|
-
})
|
|
127
|
-
], TpPasswordResetUserService);
|
|
128
|
-
export { TpPasswordResetUserService };
|
|
129
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tp-password-reset-user.service.js","sourceRoot":"C:/Projects/newrepo/kc-client/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\nimport { TpPasswordResetUser } from '../auth/auth.types';\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  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"]}
|
|
1
|
+
import { __awaiter, __decorate } from "tslib";
|
|
2
|
+
import { Inject, Injectable, Injector, NgZone } from '@angular/core';
|
|
3
|
+
import { EncryptionService } from '../cryptography/encryption.service';
|
|
4
|
+
import { KeyGraphService } from '../cryptography/key-graph.service';
|
|
5
|
+
import { LR_CONFIG } from '../life-ready.config';
|
|
6
|
+
import * as slip from '../cryptography/slip39.service';
|
|
7
|
+
import { PasswordService } from '../auth/password.service';
|
|
8
|
+
import { HttpClient } from '@angular/common/http';
|
|
9
|
+
import { AuthClass } from '@aws-amplify/auth/lib-esm/Auth';
|
|
10
|
+
import { LifeReadyAuthService } from '../auth/life-ready-auth.service';
|
|
11
|
+
import { KeyFactoryService } from '../cryptography/key-factory.service';
|
|
12
|
+
import { LrService } from '../api/lr-graphql';
|
|
13
|
+
import { RunOutsideAngular } from '../_common/run-outside-angular';
|
|
14
|
+
import * as i0 from "@angular/core";
|
|
15
|
+
import * as i1 from "../life-ready.config";
|
|
16
|
+
import * as i2 from "../cryptography/key-factory.service";
|
|
17
|
+
import * as i3 from "../cryptography/encryption.service";
|
|
18
|
+
import * as i4 from "../cryptography/key-graph.service";
|
|
19
|
+
import * as i5 from "../cryptography/slip39.service";
|
|
20
|
+
import * as i6 from "../auth/password.service";
|
|
21
|
+
import * as i7 from "@angular/common/http";
|
|
22
|
+
import * as i8 from "@aws-amplify/auth/lib-esm/Auth";
|
|
23
|
+
import * as i9 from "../auth/life-ready-auth.service";
|
|
24
|
+
let TpPasswordResetUserService = class TpPasswordResetUserService extends LrService {
|
|
25
|
+
constructor(ngZone, injector, config, keyFactory, encryptionService, keyGraphService, slip39Service, passwordService, http, auth, lrAuth) {
|
|
26
|
+
super(injector);
|
|
27
|
+
this.ngZone = ngZone;
|
|
28
|
+
this.injector = injector;
|
|
29
|
+
this.config = config;
|
|
30
|
+
this.keyFactory = keyFactory;
|
|
31
|
+
this.encryptionService = encryptionService;
|
|
32
|
+
this.keyGraphService = keyGraphService;
|
|
33
|
+
this.slip39Service = slip39Service;
|
|
34
|
+
this.passwordService = passwordService;
|
|
35
|
+
this.http = http;
|
|
36
|
+
this.auth = auth;
|
|
37
|
+
this.lrAuth = lrAuth;
|
|
38
|
+
}
|
|
39
|
+
verifyEmailContact(email) {
|
|
40
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
41
|
+
const params = {
|
|
42
|
+
email,
|
|
43
|
+
};
|
|
44
|
+
return this.http
|
|
45
|
+
.post(`${this.config.authUrl}tp/password-reset/verify-contact/`, params)
|
|
46
|
+
.toPromise();
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
verifyContactRespond(claimId, claimCode) {
|
|
50
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
51
|
+
const { token } = yield this.http
|
|
52
|
+
.post(`${this.config.authUrl}cove/respond/`, {
|
|
53
|
+
claim_id: claimId,
|
|
54
|
+
v_code: claimCode,
|
|
55
|
+
})
|
|
56
|
+
.toPromise();
|
|
57
|
+
return token;
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
requestReset(password, claimId, claimToken) {
|
|
61
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
62
|
+
// Generate the key materials
|
|
63
|
+
const passKeyBundle = yield this.passwordService.createPassKeyBundle(password);
|
|
64
|
+
const masterKey = yield this.keyFactory.createKey();
|
|
65
|
+
const wrappedMasterKey = yield this.encryptionService.encrypt(passKeyBundle.passKey, masterKey.toJSON(true));
|
|
66
|
+
// Ephemeral PKC key
|
|
67
|
+
const prk = yield this.keyFactory.createPkcKey();
|
|
68
|
+
const masterKeyWrappedPrk = yield this.encryptionService.encrypt(masterKey, prk.toJSON(true));
|
|
69
|
+
// API call to setup reset request
|
|
70
|
+
const requestResetResult = yield this.http
|
|
71
|
+
.post(`${this.config.authUrl}tp/password-reset/request/`, {
|
|
72
|
+
claimId,
|
|
73
|
+
claimToken,
|
|
74
|
+
pass_key_params: passKeyBundle.passKeyParams,
|
|
75
|
+
pass_idp_params: passKeyBundle.passIdpParams,
|
|
76
|
+
pass_idp_verifier_pbk: passKeyBundle.passIdpVerifier.toJSON(),
|
|
77
|
+
wrapped_pass_idp_verifier_prk: passKeyBundle.wrappedPassIdpVerifierPrk,
|
|
78
|
+
wrapped_master_key: wrappedMasterKey,
|
|
79
|
+
pbk: prk.toJSON(),
|
|
80
|
+
master_key_wrapped_prk: masterKeyWrappedPrk,
|
|
81
|
+
})
|
|
82
|
+
.toPromise();
|
|
83
|
+
console.log(requestResetResult);
|
|
84
|
+
console.log('Using new password: ', this.passwordService.getPassIdpString(passKeyBundle.passIdp));
|
|
85
|
+
// API call to create user on cognito
|
|
86
|
+
const signUpResult = yield this.auth.signUp({
|
|
87
|
+
username: requestResetResult.reset_username,
|
|
88
|
+
password: this.passwordService.getPassIdpString(passKeyBundle.passIdp),
|
|
89
|
+
clientMetadata: {
|
|
90
|
+
tp_password_reset_request: JSON.stringify({
|
|
91
|
+
id: requestResetResult.id,
|
|
92
|
+
associate_reset_user_token: requestResetResult.associate_reset_user_token,
|
|
93
|
+
}),
|
|
94
|
+
},
|
|
95
|
+
});
|
|
96
|
+
console.log('requestRest done: ', signUpResult);
|
|
97
|
+
return {
|
|
98
|
+
requestResetResult,
|
|
99
|
+
signUpResult,
|
|
100
|
+
};
|
|
101
|
+
});
|
|
102
|
+
}
|
|
103
|
+
};
|
|
104
|
+
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" });
|
|
105
|
+
TpPasswordResetUserService.decorators = [
|
|
106
|
+
{ type: Injectable, args: [{
|
|
107
|
+
providedIn: 'root',
|
|
108
|
+
},] }
|
|
109
|
+
];
|
|
110
|
+
TpPasswordResetUserService.ctorParameters = () => [
|
|
111
|
+
{ type: NgZone },
|
|
112
|
+
{ type: Injector },
|
|
113
|
+
{ type: undefined, decorators: [{ type: Inject, args: [LR_CONFIG,] }] },
|
|
114
|
+
{ type: KeyFactoryService },
|
|
115
|
+
{ type: EncryptionService },
|
|
116
|
+
{ type: KeyGraphService },
|
|
117
|
+
{ type: slip.Slip39Service },
|
|
118
|
+
{ type: PasswordService },
|
|
119
|
+
{ type: HttpClient },
|
|
120
|
+
{ type: AuthClass },
|
|
121
|
+
{ type: LifeReadyAuthService }
|
|
122
|
+
];
|
|
123
|
+
TpPasswordResetUserService = __decorate([
|
|
124
|
+
RunOutsideAngular({
|
|
125
|
+
ngZoneName: 'ngZone',
|
|
126
|
+
})
|
|
127
|
+
], TpPasswordResetUserService);
|
|
128
|
+
export { TpPasswordResetUserService };
|
|
129
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tp-password-reset-user.service.js","sourceRoot":"/opt/atlassian/pipelines/agent/build/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';\nimport { Inject, Injectable, Injector, NgZone } from '@angular/core';\nimport { EncryptionService } from '../cryptography/encryption.service';\nimport { KeyGraphService } from '../cryptography/key-graph.service';\nimport { LifeReadyConfig, LR_CONFIG } from '../life-ready.config';\nimport * as slip from '../cryptography/slip39.service';\nimport { JWK } from 'node-jose';\nimport { LrBadStateException, LrException } from '../_common/exceptions';\nimport {\n  CompleteTpPasswordResetRequestMutation,\n  CreateTpAssemblyKeyChallengeMutation,\n  PreCompleteTpPasswordResetRequestMutation,\n} from './tp-password-reset.gql';\nimport { PasswordService } from '../auth/password.service';\nimport { HttpClient } from '@angular/common/http';\nimport { AuthClass } from '@aws-amplify/auth/lib-esm/Auth';\nimport {\n  RequestResetResult,\n  TpPasswordResetService,\n} from './tp-password-reset.service';\nimport { ISignUpResult } from 'amazon-cognito-identity-js';\nimport { LifeReadyAuthService } from '../auth/life-ready-auth.service';\nimport { KeyFactoryService } from '../cryptography/key-factory.service';\nimport { TpClaimState, TpPasswordResetUserNode } from '../api/types';\nimport { LrMutation, LrService } from '../api/lr-graphql';\nimport { RunOutsideAngular } from '../_common/run-outside-angular';\nimport { TpPasswordResetUser } from '../auth/auth.types';\n\n@RunOutsideAngular({\n  ngZoneName: 'ngZone',\n})\n@Injectable({\n  providedIn: 'root',\n})\nexport class TpPasswordResetUserService extends LrService {\n  constructor(\n    private ngZone: NgZone,\n    private injector: Injector,\n    @Inject(LR_CONFIG) private config: LifeReadyConfig,\n    private keyFactory: KeyFactoryService,\n    private encryptionService: EncryptionService,\n    private keyGraphService: KeyGraphService,\n    private slip39Service: slip.Slip39Service,\n    private passwordService: PasswordService,\n    private http: HttpClient,\n    private auth: AuthClass,\n    private lrAuth: LifeReadyAuthService\n  ) {\n    super(injector);\n  }\n\n  async verifyEmailContact(email): Promise<{ claimId: string }> {\n    const params = {\n      email,\n    };\n    return this.http\n      .post<any>(\n        `${this.config.authUrl}tp/password-reset/verify-contact/`,\n        params\n      )\n      .toPromise();\n  }\n\n  async verifyContactRespond(\n    claimId: string,\n    claimCode: string\n  ): Promise<string> {\n    const { token } = await this.http\n      .post<{ token }>(`${this.config.authUrl}cove/respond/`, {\n        claim_id: claimId,\n        v_code: claimCode,\n      })\n      .toPromise();\n    return token;\n  }\n\n  async requestReset(\n    password: string,\n    claimId: string,\n    claimToken: string\n  ): Promise<{\n    requestResetResult: RequestResetResult;\n    signUpResult: ISignUpResult;\n  }> {\n    // Generate the key materials\n    const passKeyBundle = await this.passwordService.createPassKeyBundle(\n      password\n    );\n\n    const masterKey = await this.keyFactory.createKey();\n    const wrappedMasterKey = await this.encryptionService.encrypt(\n      passKeyBundle.passKey,\n      masterKey.toJSON(true)\n    );\n\n    // Ephemeral PKC key\n    const prk = await this.keyFactory.createPkcKey();\n    const masterKeyWrappedPrk = await this.encryptionService.encrypt(\n      masterKey,\n      prk.toJSON(true)\n    );\n\n    // API call to setup reset request\n    const requestResetResult = await this.http\n      .post<RequestResetResult>(\n        `${this.config.authUrl}tp/password-reset/request/`,\n        {\n          claimId,\n          claimToken,\n          pass_key_params: passKeyBundle.passKeyParams,\n          pass_idp_params: passKeyBundle.passIdpParams,\n          pass_idp_verifier_pbk: passKeyBundle.passIdpVerifier.toJSON(), // public key\n          wrapped_pass_idp_verifier_prk:\n            passKeyBundle.wrappedPassIdpVerifierPrk,\n          wrapped_master_key: wrappedMasterKey,\n          pbk: prk.toJSON(), // ephemeral public key\n          master_key_wrapped_prk: masterKeyWrappedPrk,\n        }\n      )\n      .toPromise();\n\n    console.log(requestResetResult);\n    console.log(\n      'Using new password: ',\n      this.passwordService.getPassIdpString(passKeyBundle.passIdp)\n    );\n\n    // API call to create user on cognito\n    const signUpResult = await this.auth.signUp({\n      username: requestResetResult.reset_username,\n      password: this.passwordService.getPassIdpString(passKeyBundle.passIdp),\n      clientMetadata: {\n        tp_password_reset_request: JSON.stringify({\n          id: requestResetResult.id,\n          associate_reset_user_token:\n            requestResetResult.associate_reset_user_token,\n        }),\n      },\n    });\n\n    console.log('requestRest done: ', signUpResult);\n\n    return {\n      requestResetResult,\n      signUpResult,\n    };\n  }\n}\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
export const TP_PASSWORD_RESET_CLIENT_NONCE_LENGTH = 32;
|
|
2
|
-
export const TP_PASSWORD_RESET_SLIP39_PASSPHRASE = 'lifeready';
|
|
3
|
-
export const TP_PASSWORD_RESET_USERNAME_SUFFIX = '.tp_password_reset';
|
|
4
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
export const TP_PASSWORD_RESET_CLIENT_NONCE_LENGTH = 32;
|
|
2
|
+
export const TP_PASSWORD_RESET_SLIP39_PASSPHRASE = 'lifeready';
|
|
3
|
+
export const TP_PASSWORD_RESET_USERNAME_SUFFIX = '.tp_password_reset';
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHAtcGFzc3dvcmQtcmVzZXQuY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6Ii9vcHQvYXRsYXNzaWFuL3BpcGVsaW5lcy9hZ2VudC9idWlsZC9wcm9qZWN0cy9jb3JlL3NyYy8iLCJzb3VyY2VzIjpbImxpYi90cnVzdGVkLXBhcnRpZXMvdHAtcGFzc3dvcmQtcmVzZXQuY29uc3RhbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBQyxNQUFNLHFDQUFxQyxHQUFHLEVBQUUsQ0FBQztBQUN4RCxNQUFNLENBQUMsTUFBTSxtQ0FBbUMsR0FBRyxXQUFXLENBQUM7QUFDL0QsTUFBTSxDQUFDLE1BQU0saUNBQWlDLEdBQUcsb0JBQW9CLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgVFBfUEFTU1dPUkRfUkVTRVRfQ0xJRU5UX05PTkNFX0xFTkdUSCA9IDMyO1xuZXhwb3J0IGNvbnN0IFRQX1BBU1NXT1JEX1JFU0VUX1NMSVAzOV9QQVNTUEhSQVNFID0gJ2xpZmVyZWFkeSc7XG5leHBvcnQgY29uc3QgVFBfUEFTU1dPUkRfUkVTRVRfVVNFUk5BTUVfU1VGRklYID0gJy50cF9wYXNzd29yZF9yZXNldCc7XG4iXX0=
|