@lifeready/core 1.0.2 → 1.0.3
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.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 +385 -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,97 +1,97 @@
|
|
|
1
|
-
import gql from 'graphql-tag';
|
|
2
|
-
import { KeyGraphFragment } from '../_common/queries.gql';
|
|
3
|
-
export const CurrentUserQuery = gql `
|
|
4
|
-
query {
|
|
5
|
-
currentUser {
|
|
6
|
-
id
|
|
7
|
-
username
|
|
8
|
-
currentUserKey {
|
|
9
|
-
passKey {
|
|
10
|
-
id
|
|
11
|
-
passKeyParams
|
|
12
|
-
passIdpParams
|
|
13
|
-
wrappedPassIdpVerifierPrk
|
|
14
|
-
created
|
|
15
|
-
}
|
|
16
|
-
masterKey {
|
|
17
|
-
id
|
|
18
|
-
}
|
|
19
|
-
rootKey {
|
|
20
|
-
id
|
|
21
|
-
}
|
|
22
|
-
pxk {
|
|
23
|
-
id
|
|
24
|
-
}
|
|
25
|
-
sigPxk {
|
|
26
|
-
id
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
userDelete {
|
|
30
|
-
id
|
|
31
|
-
created
|
|
32
|
-
state
|
|
33
|
-
}
|
|
34
|
-
features {
|
|
35
|
-
myVault
|
|
36
|
-
tpVault
|
|
37
|
-
shareVault
|
|
38
|
-
}
|
|
39
|
-
sessionEncryptionKey
|
|
40
|
-
}
|
|
41
|
-
userPlans {
|
|
42
|
-
id
|
|
43
|
-
stripe {
|
|
44
|
-
subscriptionId
|
|
45
|
-
}
|
|
46
|
-
plan {
|
|
47
|
-
name
|
|
48
|
-
data
|
|
49
|
-
state
|
|
50
|
-
}
|
|
51
|
-
periodEnd
|
|
52
|
-
}
|
|
53
|
-
contactCards(orderBy: "created") {
|
|
54
|
-
edges {
|
|
55
|
-
node {
|
|
56
|
-
id
|
|
57
|
-
key {
|
|
58
|
-
id
|
|
59
|
-
}
|
|
60
|
-
cipherData
|
|
61
|
-
plainData
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
keyGraph {
|
|
66
|
-
...KeyGraphFragment
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
${KeyGraphFragment}
|
|
70
|
-
`;
|
|
71
|
-
export const CreateContactCardMutation = gql `
|
|
72
|
-
mutation CreateContactCardMutation($input: CreateContactCardInput!) {
|
|
73
|
-
createContactCard(input: $input) {
|
|
74
|
-
contactCard {
|
|
75
|
-
id
|
|
76
|
-
key {
|
|
77
|
-
id
|
|
78
|
-
}
|
|
79
|
-
cipherData
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
`;
|
|
84
|
-
export const UpdateContactCardMutation = gql `
|
|
85
|
-
mutation UpdateContactCardMutation($input: UpdateContactCardInput!) {
|
|
86
|
-
updateContactCard(input: $input) {
|
|
87
|
-
contactCard {
|
|
88
|
-
id
|
|
89
|
-
key {
|
|
90
|
-
id
|
|
91
|
-
}
|
|
92
|
-
cipherData
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
`;
|
|
97
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import gql from 'graphql-tag';
|
|
2
|
+
import { KeyGraphFragment } from '../_common/queries.gql';
|
|
3
|
+
export const CurrentUserQuery = gql `
|
|
4
|
+
query {
|
|
5
|
+
currentUser {
|
|
6
|
+
id
|
|
7
|
+
username
|
|
8
|
+
currentUserKey {
|
|
9
|
+
passKey {
|
|
10
|
+
id
|
|
11
|
+
passKeyParams
|
|
12
|
+
passIdpParams
|
|
13
|
+
wrappedPassIdpVerifierPrk
|
|
14
|
+
created
|
|
15
|
+
}
|
|
16
|
+
masterKey {
|
|
17
|
+
id
|
|
18
|
+
}
|
|
19
|
+
rootKey {
|
|
20
|
+
id
|
|
21
|
+
}
|
|
22
|
+
pxk {
|
|
23
|
+
id
|
|
24
|
+
}
|
|
25
|
+
sigPxk {
|
|
26
|
+
id
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
userDelete {
|
|
30
|
+
id
|
|
31
|
+
created
|
|
32
|
+
state
|
|
33
|
+
}
|
|
34
|
+
features {
|
|
35
|
+
myVault
|
|
36
|
+
tpVault
|
|
37
|
+
shareVault
|
|
38
|
+
}
|
|
39
|
+
sessionEncryptionKey
|
|
40
|
+
}
|
|
41
|
+
userPlans {
|
|
42
|
+
id
|
|
43
|
+
stripe {
|
|
44
|
+
subscriptionId
|
|
45
|
+
}
|
|
46
|
+
plan {
|
|
47
|
+
name
|
|
48
|
+
data
|
|
49
|
+
state
|
|
50
|
+
}
|
|
51
|
+
periodEnd
|
|
52
|
+
}
|
|
53
|
+
contactCards(orderBy: "created") {
|
|
54
|
+
edges {
|
|
55
|
+
node {
|
|
56
|
+
id
|
|
57
|
+
key {
|
|
58
|
+
id
|
|
59
|
+
}
|
|
60
|
+
cipherData
|
|
61
|
+
plainData
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
keyGraph {
|
|
66
|
+
...KeyGraphFragment
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
${KeyGraphFragment}
|
|
70
|
+
`;
|
|
71
|
+
export const CreateContactCardMutation = gql `
|
|
72
|
+
mutation CreateContactCardMutation($input: CreateContactCardInput!) {
|
|
73
|
+
createContactCard(input: $input) {
|
|
74
|
+
contactCard {
|
|
75
|
+
id
|
|
76
|
+
key {
|
|
77
|
+
id
|
|
78
|
+
}
|
|
79
|
+
cipherData
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
`;
|
|
84
|
+
export const UpdateContactCardMutation = gql `
|
|
85
|
+
mutation UpdateContactCardMutation($input: UpdateContactCardInput!) {
|
|
86
|
+
updateContactCard(input: $input) {
|
|
87
|
+
contactCard {
|
|
88
|
+
id
|
|
89
|
+
key {
|
|
90
|
+
id
|
|
91
|
+
}
|
|
92
|
+
cipherData
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
`;
|
|
97
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZmlsZS5ncWwuanMiLCJzb3VyY2VSb290IjoiQzovUHJvamVjdHMvbmV3cmVwby9rYy1jbGllbnQvcHJvamVjdHMvY29yZS9zcmMvIiwic291cmNlcyI6WyJsaWIvdXNlcnMvcHJvZmlsZS5ncWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR0EsT0FBTyxHQUFHLE1BQU0sYUFBYSxDQUFDO0FBQzlCLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBUTFELE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHLEdBQUcsQ0FBQTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0lBa0UvQixnQkFBZ0I7Q0FDbkIsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLHlCQUF5QixHQUFHLEdBQUcsQ0FBQTs7Ozs7Ozs7Ozs7O0NBWTNDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSx5QkFBeUIsR0FBRyxHQUFHLENBQUE7Ozs7Ozs7Ozs7OztDQVkzQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSGFzRWRnZXMgfSBmcm9tICcuLy4uL19jb21tb24vdHlwZXMnO1xyXG5pbXBvcnQgeyBIYXNLZXlHcmFwaCwgUGFzc0tleSB9IGZyb20gJy4vLi4vY3J5cHRvZ3JhcGh5L2NyeXB0b2dyYXBoeS50eXBlcyc7XHJcbmltcG9ydCB7IEFwaUN1cnJlbnRVc2VyLCBBcGlDb250YWN0Q2FyZCB9IGZyb20gJy4vcHJvZmlsZS50eXBlcyc7XHJcbmltcG9ydCBncWwgZnJvbSAnZ3JhcGhxbC10YWcnO1xyXG5pbXBvcnQgeyBLZXlHcmFwaEZyYWdtZW50IH0gZnJvbSAnLi4vX2NvbW1vbi9xdWVyaWVzLmdxbCc7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEN1cnJlbnRVc2VyUXVlcnlUeXBlIGV4dGVuZHMgSGFzS2V5R3JhcGgge1xyXG4gIGN1cnJlbnRVc2VyOiBBcGlDdXJyZW50VXNlcjtcclxuICBjb250YWN0Q2FyZHM6IEhhc0VkZ2VzPEFwaUNvbnRhY3RDYXJkPjtcclxuICB1c2VyUGxhbnM6IGFueVtdO1xyXG59XHJcblxyXG5leHBvcnQgY29uc3QgQ3VycmVudFVzZXJRdWVyeSA9IGdxbGBcclxuICBxdWVyeSB7XHJcbiAgICBjdXJyZW50VXNlciB7XHJcbiAgICAgIGlkXHJcbiAgICAgIHVzZXJuYW1lXHJcbiAgICAgIGN1cnJlbnRVc2VyS2V5IHtcclxuICAgICAgICBwYXNzS2V5IHtcclxuICAgICAgICAgIGlkXHJcbiAgICAgICAgICBwYXNzS2V5UGFyYW1zXHJcbiAgICAgICAgICBwYXNzSWRwUGFyYW1zXHJcbiAgICAgICAgICB3cmFwcGVkUGFzc0lkcFZlcmlmaWVyUHJrXHJcbiAgICAgICAgICBjcmVhdGVkXHJcbiAgICAgICAgfVxyXG4gICAgICAgIG1hc3RlcktleSB7XHJcbiAgICAgICAgICBpZFxyXG4gICAgICAgIH1cclxuICAgICAgICByb290S2V5IHtcclxuICAgICAgICAgIGlkXHJcbiAgICAgICAgfVxyXG4gICAgICAgIHB4ayB7XHJcbiAgICAgICAgICBpZFxyXG4gICAgICAgIH1cclxuICAgICAgICBzaWdQeGsge1xyXG4gICAgICAgICAgaWRcclxuICAgICAgICB9XHJcbiAgICAgIH1cclxuICAgICAgdXNlckRlbGV0ZSB7XHJcbiAgICAgICAgaWRcclxuICAgICAgICBjcmVhdGVkXHJcbiAgICAgICAgc3RhdGVcclxuICAgICAgfVxyXG4gICAgICBmZWF0dXJlcyB7XHJcbiAgICAgICAgbXlWYXVsdFxyXG4gICAgICAgIHRwVmF1bHRcclxuICAgICAgICBzaGFyZVZhdWx0XHJcbiAgICAgIH1cclxuICAgICAgc2Vzc2lvbkVuY3J5cHRpb25LZXlcclxuICAgIH1cclxuICAgIHVzZXJQbGFucyB7XHJcbiAgICAgIGlkXHJcbiAgICAgIHN0cmlwZSB7XHJcbiAgICAgICAgc3Vic2NyaXB0aW9uSWRcclxuICAgICAgfVxyXG4gICAgICBwbGFuIHtcclxuICAgICAgICBuYW1lXHJcbiAgICAgICAgZGF0YVxyXG4gICAgICAgIHN0YXRlXHJcbiAgICAgIH1cclxuICAgICAgcGVyaW9kRW5kXHJcbiAgICB9XHJcbiAgICBjb250YWN0Q2FyZHMob3JkZXJCeTogXCJjcmVhdGVkXCIpIHtcclxuICAgICAgZWRnZXMge1xyXG4gICAgICAgIG5vZGUge1xyXG4gICAgICAgICAgaWRcclxuICAgICAgICAgIGtleSB7XHJcbiAgICAgICAgICAgIGlkXHJcbiAgICAgICAgICB9XHJcbiAgICAgICAgICBjaXBoZXJEYXRhXHJcbiAgICAgICAgICBwbGFpbkRhdGFcclxuICAgICAgICB9XHJcbiAgICAgIH1cclxuICAgIH1cclxuICAgIGtleUdyYXBoIHtcclxuICAgICAgLi4uS2V5R3JhcGhGcmFnbWVudFxyXG4gICAgfVxyXG4gIH1cclxuICAke0tleUdyYXBoRnJhZ21lbnR9XHJcbmA7XHJcblxyXG5leHBvcnQgY29uc3QgQ3JlYXRlQ29udGFjdENhcmRNdXRhdGlvbiA9IGdxbGBcclxuICBtdXRhdGlvbiBDcmVhdGVDb250YWN0Q2FyZE11dGF0aW9uKCRpbnB1dDogQ3JlYXRlQ29udGFjdENhcmRJbnB1dCEpIHtcclxuICAgIGNyZWF0ZUNvbnRhY3RDYXJkKGlucHV0OiAkaW5wdXQpIHtcclxuICAgICAgY29udGFjdENhcmQge1xyXG4gICAgICAgIGlkXHJcbiAgICAgICAga2V5IHtcclxuICAgICAgICAgIGlkXHJcbiAgICAgICAgfVxyXG4gICAgICAgIGNpcGhlckRhdGFcclxuICAgICAgfVxyXG4gICAgfVxyXG4gIH1cclxuYDtcclxuXHJcbmV4cG9ydCBjb25zdCBVcGRhdGVDb250YWN0Q2FyZE11dGF0aW9uID0gZ3FsYFxyXG4gIG11dGF0aW9uIFVwZGF0ZUNvbnRhY3RDYXJkTXV0YXRpb24oJGlucHV0OiBVcGRhdGVDb250YWN0Q2FyZElucHV0ISkge1xyXG4gICAgdXBkYXRlQ29udGFjdENhcmQoaW5wdXQ6ICRpbnB1dCkge1xyXG4gICAgICBjb250YWN0Q2FyZCB7XHJcbiAgICAgICAgaWRcclxuICAgICAgICBrZXkge1xyXG4gICAgICAgICAgaWRcclxuICAgICAgICB9XHJcbiAgICAgICAgY2lwaGVyRGF0YVxyXG4gICAgICB9XHJcbiAgICB9XHJcbiAgfVxyXG5gO1xyXG4iXX0=
|
|
@@ -1,169 +1,169 @@
|
|
|
1
|
-
import { __awaiter } from "tslib";
|
|
2
|
-
import { HttpClient } from '@angular/common/http';
|
|
3
|
-
import { Inject, Injectable } from '@angular/core';
|
|
4
|
-
import { LrApolloService } from '../api/lr-apollo.service';
|
|
5
|
-
import { LR_CONFIG } from '../life-ready.config';
|
|
6
|
-
import { CurrentUserQuery, UpdateContactCardMutation, CreateContactCardMutation, } from './profile.gql';
|
|
7
|
-
import { ContactCardName, } from './profile.types';
|
|
8
|
-
import { KeyMetaService } from '../cryptography/key-meta.service';
|
|
9
|
-
import { KeyService } from '../cryptography/key.service';
|
|
10
|
-
import { EncryptionService } from '../cryptography/encryption.service';
|
|
11
|
-
import { ContactCardListQuery, DeleteContactCardMutation, } from '../api/contact-card.gql';
|
|
12
|
-
import { mapUserPlans } from '../plan/plan.service';
|
|
13
|
-
import { KeyGraphService } from '../cryptography/key-graph.service';
|
|
14
|
-
import * as i0 from "@angular/core";
|
|
15
|
-
import * as i1 from "../life-ready.config";
|
|
16
|
-
import * as i2 from "@angular/common/http";
|
|
17
|
-
import * as i3 from "../api/lr-apollo.service";
|
|
18
|
-
import * as i4 from "../cryptography/key.service";
|
|
19
|
-
import * as i5 from "../cryptography/key-meta.service";
|
|
20
|
-
import * as i6 from "../cryptography/key-graph.service";
|
|
21
|
-
import * as i7 from "../cryptography/encryption.service";
|
|
22
|
-
export class ProfileService {
|
|
23
|
-
constructor(config, http, lrApollo, keyService, keyMetaService, keyGraph, encryptionService) {
|
|
24
|
-
this.config = config;
|
|
25
|
-
this.http = http;
|
|
26
|
-
this.lrApollo = lrApollo;
|
|
27
|
-
this.keyService = keyService;
|
|
28
|
-
this.keyMetaService = keyMetaService;
|
|
29
|
-
this.keyGraph = keyGraph;
|
|
30
|
-
this.encryptionService = encryptionService;
|
|
31
|
-
}
|
|
32
|
-
getPassIdpParams(emailOrPhone) {
|
|
33
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
34
|
-
return yield this.http
|
|
35
|
-
.get(`${this.config.authUrl}users/pass-idp-params/?login_name=${encodeURIComponent(emailOrPhone)}`)
|
|
36
|
-
.toPromise();
|
|
37
|
-
});
|
|
38
|
-
}
|
|
39
|
-
getCurrentUser() {
|
|
40
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
41
|
-
const { currentUser, contactCards, userPlans, } = yield this.lrApollo.query({
|
|
42
|
-
query: CurrentUserQuery,
|
|
43
|
-
});
|
|
44
|
-
const contactCard = contactCards.edges.map((x) => x.node)[0];
|
|
45
|
-
return {
|
|
46
|
-
currentUser,
|
|
47
|
-
contactCard,
|
|
48
|
-
userPlans: mapUserPlans(userPlans),
|
|
49
|
-
};
|
|
50
|
-
});
|
|
51
|
-
}
|
|
52
|
-
decryptContactCard(contactCard) {
|
|
53
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
54
|
-
if (!contactCard) {
|
|
55
|
-
return null;
|
|
56
|
-
}
|
|
57
|
-
const details = yield this.keyGraph.decryptFromString(contactCard.key.id, contactCard.cipherData);
|
|
58
|
-
return Object.assign({ id: contactCard.id, keyId: contactCard.key.id }, details);
|
|
59
|
-
});
|
|
60
|
-
}
|
|
61
|
-
updateDetails(id, keyId, fields) {
|
|
62
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
63
|
-
yield (id
|
|
64
|
-
? this.updateContactCard(id, keyId, fields)
|
|
65
|
-
: this.createContactCard(fields));
|
|
66
|
-
});
|
|
67
|
-
}
|
|
68
|
-
prepareContactCardInput(contactCard) {
|
|
69
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
70
|
-
const sigPxk = yield this.keyService.getCurrentSigPxk();
|
|
71
|
-
const publicDataSig = JSON.stringify(yield this.encryptionService.sign(sigPxk.jwk, ''));
|
|
72
|
-
const publicSearchableSig = JSON.stringify(yield this.encryptionService.sign(sigPxk.jwk, ''));
|
|
73
|
-
const plainDataJson = {
|
|
74
|
-
// contactCard.name.value may have additional attributes such as the id of the contact card.
|
|
75
|
-
// So we create a clean version. Otherwise it will fail server checks.
|
|
76
|
-
name: new ContactCardName(contactCard.name.value),
|
|
77
|
-
};
|
|
78
|
-
const plainDataSig = JSON.stringify(yield this.encryptionService.sign(sigPxk.jwk, plainDataJson));
|
|
79
|
-
return {
|
|
80
|
-
sigPxkId: sigPxk.id,
|
|
81
|
-
publicDataSig,
|
|
82
|
-
publicSearchableSig,
|
|
83
|
-
plainDataSig,
|
|
84
|
-
};
|
|
85
|
-
});
|
|
86
|
-
}
|
|
87
|
-
createContactCard(contactCard) {
|
|
88
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
89
|
-
const input = yield this.prepareContactCardInput(contactCard);
|
|
90
|
-
const { rootKey, cipherMeta } = yield this.keyMetaService.wrapContent(contactCard);
|
|
91
|
-
const data = yield this.lrApollo.mutate({
|
|
92
|
-
mutation: CreateContactCardMutation,
|
|
93
|
-
variables: {
|
|
94
|
-
input: Object.assign(Object.assign({}, input), { cipherData: cipherMeta, wrappingKeyId: rootKey.wrappingKeyId, wrappedKey: rootKey.wrappedKey, default: true }),
|
|
95
|
-
},
|
|
96
|
-
});
|
|
97
|
-
return data.createContactCard.contactCard;
|
|
98
|
-
});
|
|
99
|
-
}
|
|
100
|
-
updateContactCard(id, keyId, contactCard) {
|
|
101
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
102
|
-
const input = yield this.prepareContactCardInput(contactCard);
|
|
103
|
-
const cipherData = yield this.keyGraph.encryptToString(keyId, contactCard);
|
|
104
|
-
const data = yield this.lrApollo.mutate({
|
|
105
|
-
mutation: UpdateContactCardMutation,
|
|
106
|
-
variables: {
|
|
107
|
-
input: Object.assign(Object.assign({}, input), { id,
|
|
108
|
-
cipherData }),
|
|
109
|
-
},
|
|
110
|
-
});
|
|
111
|
-
return data.updateContactCard.contactCard;
|
|
112
|
-
});
|
|
113
|
-
}
|
|
114
|
-
decryptContactCardEdges(edges) {
|
|
115
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
116
|
-
return Promise.all(edges.map((edge) => __awaiter(this, void 0, void 0, function* () {
|
|
117
|
-
const cc = edge.node;
|
|
118
|
-
return yield this.decryptContactCard(cc);
|
|
119
|
-
})));
|
|
120
|
-
});
|
|
121
|
-
}
|
|
122
|
-
getContactCards() {
|
|
123
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
124
|
-
const data = yield this.lrApollo.query({
|
|
125
|
-
query: ContactCardListQuery,
|
|
126
|
-
});
|
|
127
|
-
return yield this.decryptContactCardEdges(data.contactCards.edges);
|
|
128
|
-
});
|
|
129
|
-
}
|
|
130
|
-
deleteContactCard(id) {
|
|
131
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
132
|
-
const data = yield this.lrApollo.mutate({
|
|
133
|
-
mutation: DeleteContactCardMutation,
|
|
134
|
-
variables: {
|
|
135
|
-
input: {
|
|
136
|
-
id,
|
|
137
|
-
},
|
|
138
|
-
},
|
|
139
|
-
});
|
|
140
|
-
return data.deleteContactCard.id;
|
|
141
|
-
});
|
|
142
|
-
}
|
|
143
|
-
signOut() {
|
|
144
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
145
|
-
yield this.http
|
|
146
|
-
.post(`${this.config.authUrl}auth/sign-out/`, null, {
|
|
147
|
-
withCredentials: true,
|
|
148
|
-
responseType: 'text',
|
|
149
|
-
})
|
|
150
|
-
.toPromise();
|
|
151
|
-
});
|
|
152
|
-
}
|
|
153
|
-
}
|
|
154
|
-
ProfileService.ɵprov = i0.ɵɵdefineInjectable({ factory: function ProfileService_Factory() { return new ProfileService(i0.ɵɵinject(i1.LR_CONFIG), i0.ɵɵinject(i2.HttpClient), i0.ɵɵinject(i3.LrApolloService), i0.ɵɵinject(i4.KeyService), i0.ɵɵinject(i5.KeyMetaService), i0.ɵɵinject(i6.KeyGraphService), i0.ɵɵinject(i7.EncryptionService)); }, token: ProfileService, providedIn: "root" });
|
|
155
|
-
ProfileService.decorators = [
|
|
156
|
-
{ type: Injectable, args: [{
|
|
157
|
-
providedIn: 'root',
|
|
158
|
-
},] }
|
|
159
|
-
];
|
|
160
|
-
ProfileService.ctorParameters = () => [
|
|
161
|
-
{ type: undefined, decorators: [{ type: Inject, args: [LR_CONFIG,] }] },
|
|
162
|
-
{ type: HttpClient },
|
|
163
|
-
{ type: LrApolloService },
|
|
164
|
-
{ type: KeyService },
|
|
165
|
-
{ type: KeyMetaService },
|
|
166
|
-
{ type: KeyGraphService },
|
|
167
|
-
{ type: EncryptionService }
|
|
168
|
-
];
|
|
169
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"profile.service.js","sourceRoot":"/opt/atlassian/pipelines/agent/build/projects/core/src/","sources":["lib/users/profile.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\nimport { Inject, Injectable } from '@angular/core';\nimport { LrApolloService } from '../api/lr-apollo.service';\nimport { LifeReadyConfig, LR_CONFIG } from '../life-ready.config';\nimport {\n  CurrentUserQuery,\n  CurrentUserQueryType,\n  UpdateContactCardMutation,\n  CreateContactCardMutation,\n} from './profile.gql';\nimport {\n  ApiCurrentUser,\n  PassIdpApiResult,\n  MainContactCard,\n  ApiContactCard,\n  MainContactCardFields,\n  MainContactCardPlainFields,\n  ContactCardName,\n} from './profile.types';\nimport { KeyMetaService } from '../cryptography/key-meta.service';\nimport { KeyService } from '../cryptography/key.service';\nimport { EncryptionService } from '../cryptography/encryption.service';\nimport { ContactCard } from '../api/contact-card.service';\nimport {\n  ContactCardListQuery,\n  DeleteContactCardMutation,\n} from '../api/contact-card.gql';\nimport { mapUserPlans } from '../plan/plan.service';\nimport { UserPlan } from '../plan/plan.types';\nimport { KeyGraphService } from '../cryptography/key-graph.service';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class ProfileService {\n  constructor(\n    @Inject(LR_CONFIG) private config: LifeReadyConfig,\n    private http: HttpClient,\n    private lrApollo: LrApolloService,\n    private keyService: KeyService,\n    private keyMetaService: KeyMetaService,\n    private keyGraph: KeyGraphService,\n    private encryptionService: EncryptionService\n  ) {}\n\n  async getPassIdpParams(emailOrPhone: string): Promise<PassIdpApiResult> {\n    return await this.http\n      .get<PassIdpApiResult>(\n        `${\n          this.config.authUrl\n        }users/pass-idp-params/?login_name=${encodeURIComponent(emailOrPhone)}`\n      )\n      .toPromise();\n  }\n\n  async getCurrentUser(): Promise<{\n    currentUser: ApiCurrentUser;\n    contactCard: ApiContactCard;\n    userPlans: UserPlan[];\n  }> {\n    const {\n      currentUser,\n      contactCards,\n      userPlans,\n    } = await this.lrApollo.query<CurrentUserQueryType>({\n      query: CurrentUserQuery,\n    });\n\n    const contactCard = contactCards.edges.map((x) => x.node)[0];\n\n    return {\n      currentUser,\n      contactCard,\n      userPlans: mapUserPlans(userPlans),\n    };\n  }\n\n  async decryptContactCard(\n    contactCard: ApiContactCard\n  ): Promise<MainContactCard> {\n    if (!contactCard) {\n      return null;\n    }\n\n    const details = await this.keyGraph.decryptFromString<any>(\n      contactCard.key.id,\n      contactCard.cipherData\n    );\n\n    return {\n      id: contactCard.id,\n      keyId: contactCard.key.id,\n      ...details,\n    };\n  }\n\n  async updateDetails(\n    id: string,\n    keyId: string,\n    fields: MainContactCardFields\n  ): Promise<void> {\n    await (id\n      ? this.updateContactCard(id, keyId, fields)\n      : this.createContactCard(fields));\n  }\n\n  private async prepareContactCardInput(\n    contactCard: MainContactCardFields\n  ): Promise<any> {\n    const sigPxk = await this.keyService.getCurrentSigPxk();\n\n    const publicDataSig = JSON.stringify(\n      await this.encryptionService.sign(sigPxk.jwk, '')\n    );\n    const publicSearchableSig = JSON.stringify(\n      await this.encryptionService.sign(sigPxk.jwk, '')\n    );\n\n    const plainDataJson: MainContactCardPlainFields = {\n      // contactCard.name.value may have additional attributes such as the id of the contact card.\n      // So we create a clean version. Otherwise it will fail server checks.\n      name: new ContactCardName(contactCard.name.value),\n    };\n    const plainDataSig = JSON.stringify(\n      await this.encryptionService.sign(sigPxk.jwk, plainDataJson)\n    );\n\n    return {\n      sigPxkId: sigPxk.id,\n      publicDataSig,\n      publicSearchableSig,\n      plainDataSig,\n    };\n  }\n\n  private async createContactCard(\n    contactCard: MainContactCardFields\n  ): Promise<ApiContactCard> {\n    const input = await this.prepareContactCardInput(contactCard);\n\n    const { rootKey, cipherMeta } = await this.keyMetaService.wrapContent(\n      contactCard\n    );\n\n    const data = await this.lrApollo.mutate<{\n      createContactCard: { contactCard: ApiContactCard };\n    }>({\n      mutation: CreateContactCardMutation,\n      variables: {\n        input: {\n          ...input,\n          cipherData: cipherMeta,\n          wrappingKeyId: rootKey.wrappingKeyId,\n          wrappedKey: rootKey.wrappedKey,\n          default: true, // Use this contact card as default contact card.\n        },\n      },\n    });\n    return data.createContactCard.contactCard;\n  }\n\n  private async updateContactCard(\n    id: string,\n    keyId: string,\n    contactCard: MainContactCardFields\n  ): Promise<ApiContactCard> {\n    const input = await this.prepareContactCardInput(contactCard);\n\n    const cipherData = await this.keyGraph.encryptToString(keyId, contactCard);\n\n    const data = await this.lrApollo.mutate<{\n      updateContactCard: { contactCard: ApiContactCard };\n    }>({\n      mutation: UpdateContactCardMutation,\n      variables: {\n        input: {\n          ...input,\n          id,\n          cipherData,\n        },\n      },\n    });\n    return data.updateContactCard.contactCard;\n  }\n\n  async decryptContactCardEdges(edges): Promise<ContactCard[]> {\n    return Promise.all(\n      edges.map(async (edge: any) => {\n        const cc = edge.node as ContactCard;\n        return await this.decryptContactCard(cc);\n      })\n    );\n  }\n\n  async getContactCards(): Promise<ContactCard[]> {\n    const data = await this.lrApollo.query<any>({\n      query: ContactCardListQuery,\n    });\n\n    return await this.decryptContactCardEdges(data.contactCards.edges);\n  }\n\n  async deleteContactCard(id: string): Promise<string> {\n    const data = await this.lrApollo.mutate<any>({\n      mutation: DeleteContactCardMutation,\n      variables: {\n        input: {\n          id,\n        },\n      },\n    });\n\n    return data.deleteContactCard.id;\n  }\n\n  async signOut(): Promise<void> {\n    await this.http\n      .post(`${this.config.authUrl}auth/sign-out/`, null, {\n        withCredentials: true,\n        responseType: 'text',\n      })\n      .toPromise();\n  }\n}\n"]}
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
2
|
+
import { HttpClient } from '@angular/common/http';
|
|
3
|
+
import { Inject, Injectable } from '@angular/core';
|
|
4
|
+
import { LrApolloService } from '../api/lr-apollo.service';
|
|
5
|
+
import { LR_CONFIG } from '../life-ready.config';
|
|
6
|
+
import { CurrentUserQuery, UpdateContactCardMutation, CreateContactCardMutation, } from './profile.gql';
|
|
7
|
+
import { ContactCardName, } from './profile.types';
|
|
8
|
+
import { KeyMetaService } from '../cryptography/key-meta.service';
|
|
9
|
+
import { KeyService } from '../cryptography/key.service';
|
|
10
|
+
import { EncryptionService } from '../cryptography/encryption.service';
|
|
11
|
+
import { ContactCardListQuery, DeleteContactCardMutation, } from '../api/contact-card.gql';
|
|
12
|
+
import { mapUserPlans } from '../plan/plan.service';
|
|
13
|
+
import { KeyGraphService } from '../cryptography/key-graph.service';
|
|
14
|
+
import * as i0 from "@angular/core";
|
|
15
|
+
import * as i1 from "../life-ready.config";
|
|
16
|
+
import * as i2 from "@angular/common/http";
|
|
17
|
+
import * as i3 from "../api/lr-apollo.service";
|
|
18
|
+
import * as i4 from "../cryptography/key.service";
|
|
19
|
+
import * as i5 from "../cryptography/key-meta.service";
|
|
20
|
+
import * as i6 from "../cryptography/key-graph.service";
|
|
21
|
+
import * as i7 from "../cryptography/encryption.service";
|
|
22
|
+
export class ProfileService {
|
|
23
|
+
constructor(config, http, lrApollo, keyService, keyMetaService, keyGraph, encryptionService) {
|
|
24
|
+
this.config = config;
|
|
25
|
+
this.http = http;
|
|
26
|
+
this.lrApollo = lrApollo;
|
|
27
|
+
this.keyService = keyService;
|
|
28
|
+
this.keyMetaService = keyMetaService;
|
|
29
|
+
this.keyGraph = keyGraph;
|
|
30
|
+
this.encryptionService = encryptionService;
|
|
31
|
+
}
|
|
32
|
+
getPassIdpParams(emailOrPhone) {
|
|
33
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
34
|
+
return yield this.http
|
|
35
|
+
.get(`${this.config.authUrl}users/pass-idp-params/?login_name=${encodeURIComponent(emailOrPhone)}`)
|
|
36
|
+
.toPromise();
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
getCurrentUser() {
|
|
40
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
41
|
+
const { currentUser, contactCards, userPlans, } = yield this.lrApollo.query({
|
|
42
|
+
query: CurrentUserQuery,
|
|
43
|
+
});
|
|
44
|
+
const contactCard = contactCards.edges.map((x) => x.node)[0];
|
|
45
|
+
return {
|
|
46
|
+
currentUser,
|
|
47
|
+
contactCard,
|
|
48
|
+
userPlans: mapUserPlans(userPlans),
|
|
49
|
+
};
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
decryptContactCard(contactCard) {
|
|
53
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
54
|
+
if (!contactCard) {
|
|
55
|
+
return null;
|
|
56
|
+
}
|
|
57
|
+
const details = yield this.keyGraph.decryptFromString(contactCard.key.id, contactCard.cipherData);
|
|
58
|
+
return Object.assign({ id: contactCard.id, keyId: contactCard.key.id }, details);
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
updateDetails(id, keyId, fields) {
|
|
62
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
63
|
+
yield (id
|
|
64
|
+
? this.updateContactCard(id, keyId, fields)
|
|
65
|
+
: this.createContactCard(fields));
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
prepareContactCardInput(contactCard) {
|
|
69
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
70
|
+
const sigPxk = yield this.keyService.getCurrentSigPxk();
|
|
71
|
+
const publicDataSig = JSON.stringify(yield this.encryptionService.sign(sigPxk.jwk, ''));
|
|
72
|
+
const publicSearchableSig = JSON.stringify(yield this.encryptionService.sign(sigPxk.jwk, ''));
|
|
73
|
+
const plainDataJson = {
|
|
74
|
+
// contactCard.name.value may have additional attributes such as the id of the contact card.
|
|
75
|
+
// So we create a clean version. Otherwise it will fail server checks.
|
|
76
|
+
name: new ContactCardName(contactCard.name.value),
|
|
77
|
+
};
|
|
78
|
+
const plainDataSig = JSON.stringify(yield this.encryptionService.sign(sigPxk.jwk, plainDataJson));
|
|
79
|
+
return {
|
|
80
|
+
sigPxkId: sigPxk.id,
|
|
81
|
+
publicDataSig,
|
|
82
|
+
publicSearchableSig,
|
|
83
|
+
plainDataSig,
|
|
84
|
+
};
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
createContactCard(contactCard) {
|
|
88
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
89
|
+
const input = yield this.prepareContactCardInput(contactCard);
|
|
90
|
+
const { rootKey, cipherMeta } = yield this.keyMetaService.wrapContent(contactCard);
|
|
91
|
+
const data = yield this.lrApollo.mutate({
|
|
92
|
+
mutation: CreateContactCardMutation,
|
|
93
|
+
variables: {
|
|
94
|
+
input: Object.assign(Object.assign({}, input), { cipherData: cipherMeta, wrappingKeyId: rootKey.wrappingKeyId, wrappedKey: rootKey.wrappedKey, default: true }),
|
|
95
|
+
},
|
|
96
|
+
});
|
|
97
|
+
return data.createContactCard.contactCard;
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
updateContactCard(id, keyId, contactCard) {
|
|
101
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
102
|
+
const input = yield this.prepareContactCardInput(contactCard);
|
|
103
|
+
const cipherData = yield this.keyGraph.encryptToString(keyId, contactCard);
|
|
104
|
+
const data = yield this.lrApollo.mutate({
|
|
105
|
+
mutation: UpdateContactCardMutation,
|
|
106
|
+
variables: {
|
|
107
|
+
input: Object.assign(Object.assign({}, input), { id,
|
|
108
|
+
cipherData }),
|
|
109
|
+
},
|
|
110
|
+
});
|
|
111
|
+
return data.updateContactCard.contactCard;
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
decryptContactCardEdges(edges) {
|
|
115
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
116
|
+
return Promise.all(edges.map((edge) => __awaiter(this, void 0, void 0, function* () {
|
|
117
|
+
const cc = edge.node;
|
|
118
|
+
return yield this.decryptContactCard(cc);
|
|
119
|
+
})));
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
getContactCards() {
|
|
123
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
124
|
+
const data = yield this.lrApollo.query({
|
|
125
|
+
query: ContactCardListQuery,
|
|
126
|
+
});
|
|
127
|
+
return yield this.decryptContactCardEdges(data.contactCards.edges);
|
|
128
|
+
});
|
|
129
|
+
}
|
|
130
|
+
deleteContactCard(id) {
|
|
131
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
132
|
+
const data = yield this.lrApollo.mutate({
|
|
133
|
+
mutation: DeleteContactCardMutation,
|
|
134
|
+
variables: {
|
|
135
|
+
input: {
|
|
136
|
+
id,
|
|
137
|
+
},
|
|
138
|
+
},
|
|
139
|
+
});
|
|
140
|
+
return data.deleteContactCard.id;
|
|
141
|
+
});
|
|
142
|
+
}
|
|
143
|
+
signOut() {
|
|
144
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
145
|
+
yield this.http
|
|
146
|
+
.post(`${this.config.authUrl}auth/sign-out/`, null, {
|
|
147
|
+
withCredentials: true,
|
|
148
|
+
responseType: 'text',
|
|
149
|
+
})
|
|
150
|
+
.toPromise();
|
|
151
|
+
});
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
ProfileService.ɵprov = i0.ɵɵdefineInjectable({ factory: function ProfileService_Factory() { return new ProfileService(i0.ɵɵinject(i1.LR_CONFIG), i0.ɵɵinject(i2.HttpClient), i0.ɵɵinject(i3.LrApolloService), i0.ɵɵinject(i4.KeyService), i0.ɵɵinject(i5.KeyMetaService), i0.ɵɵinject(i6.KeyGraphService), i0.ɵɵinject(i7.EncryptionService)); }, token: ProfileService, providedIn: "root" });
|
|
155
|
+
ProfileService.decorators = [
|
|
156
|
+
{ type: Injectable, args: [{
|
|
157
|
+
providedIn: 'root',
|
|
158
|
+
},] }
|
|
159
|
+
];
|
|
160
|
+
ProfileService.ctorParameters = () => [
|
|
161
|
+
{ type: undefined, decorators: [{ type: Inject, args: [LR_CONFIG,] }] },
|
|
162
|
+
{ type: HttpClient },
|
|
163
|
+
{ type: LrApolloService },
|
|
164
|
+
{ type: KeyService },
|
|
165
|
+
{ type: KeyMetaService },
|
|
166
|
+
{ type: KeyGraphService },
|
|
167
|
+
{ type: EncryptionService }
|
|
168
|
+
];
|
|
169
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"profile.service.js","sourceRoot":"C:/Projects/newrepo/kc-client/projects/core/src/","sources":["lib/users/profile.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\r\nimport { Inject, Injectable } from '@angular/core';\r\nimport { LrApolloService } from '../api/lr-apollo.service';\r\nimport { LifeReadyConfig, LR_CONFIG } from '../life-ready.config';\r\nimport {\r\n  CurrentUserQuery,\r\n  CurrentUserQueryType,\r\n  UpdateContactCardMutation,\r\n  CreateContactCardMutation,\r\n} from './profile.gql';\r\nimport {\r\n  ApiCurrentUser,\r\n  PassIdpApiResult,\r\n  MainContactCard,\r\n  ApiContactCard,\r\n  MainContactCardFields,\r\n  MainContactCardPlainFields,\r\n  ContactCardName,\r\n} from './profile.types';\r\nimport { KeyMetaService } from '../cryptography/key-meta.service';\r\nimport { KeyService } from '../cryptography/key.service';\r\nimport { EncryptionService } from '../cryptography/encryption.service';\r\nimport { ContactCard } from '../api/contact-card.service';\r\nimport {\r\n  ContactCardListQuery,\r\n  DeleteContactCardMutation,\r\n} from '../api/contact-card.gql';\r\nimport { mapUserPlans } from '../plan/plan.service';\r\nimport { UserPlan } from '../plan/plan.types';\r\nimport { KeyGraphService } from '../cryptography/key-graph.service';\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class ProfileService {\r\n  constructor(\r\n    @Inject(LR_CONFIG) private config: LifeReadyConfig,\r\n    private http: HttpClient,\r\n    private lrApollo: LrApolloService,\r\n    private keyService: KeyService,\r\n    private keyMetaService: KeyMetaService,\r\n    private keyGraph: KeyGraphService,\r\n    private encryptionService: EncryptionService\r\n  ) {}\r\n\r\n  async getPassIdpParams(emailOrPhone: string): Promise<PassIdpApiResult> {\r\n    return await this.http\r\n      .get<PassIdpApiResult>(\r\n        `${\r\n          this.config.authUrl\r\n        }users/pass-idp-params/?login_name=${encodeURIComponent(emailOrPhone)}`\r\n      )\r\n      .toPromise();\r\n  }\r\n\r\n  async getCurrentUser(): Promise<{\r\n    currentUser: ApiCurrentUser;\r\n    contactCard: ApiContactCard;\r\n    userPlans: UserPlan[];\r\n  }> {\r\n    const {\r\n      currentUser,\r\n      contactCards,\r\n      userPlans,\r\n    } = await this.lrApollo.query<CurrentUserQueryType>({\r\n      query: CurrentUserQuery,\r\n    });\r\n\r\n    const contactCard = contactCards.edges.map((x) => x.node)[0];\r\n\r\n    return {\r\n      currentUser,\r\n      contactCard,\r\n      userPlans: mapUserPlans(userPlans),\r\n    };\r\n  }\r\n\r\n  async decryptContactCard(\r\n    contactCard: ApiContactCard\r\n  ): Promise<MainContactCard> {\r\n    if (!contactCard) {\r\n      return null;\r\n    }\r\n\r\n    const details = await this.keyGraph.decryptFromString<any>(\r\n      contactCard.key.id,\r\n      contactCard.cipherData\r\n    );\r\n\r\n    return {\r\n      id: contactCard.id,\r\n      keyId: contactCard.key.id,\r\n      ...details,\r\n    };\r\n  }\r\n\r\n  async updateDetails(\r\n    id: string,\r\n    keyId: string,\r\n    fields: MainContactCardFields\r\n  ): Promise<void> {\r\n    await (id\r\n      ? this.updateContactCard(id, keyId, fields)\r\n      : this.createContactCard(fields));\r\n  }\r\n\r\n  private async prepareContactCardInput(\r\n    contactCard: MainContactCardFields\r\n  ): Promise<any> {\r\n    const sigPxk = await this.keyService.getCurrentSigPxk();\r\n\r\n    const publicDataSig = JSON.stringify(\r\n      await this.encryptionService.sign(sigPxk.jwk, '')\r\n    );\r\n    const publicSearchableSig = JSON.stringify(\r\n      await this.encryptionService.sign(sigPxk.jwk, '')\r\n    );\r\n\r\n    const plainDataJson: MainContactCardPlainFields = {\r\n      // contactCard.name.value may have additional attributes such as the id of the contact card.\r\n      // So we create a clean version. Otherwise it will fail server checks.\r\n      name: new ContactCardName(contactCard.name.value),\r\n    };\r\n    const plainDataSig = JSON.stringify(\r\n      await this.encryptionService.sign(sigPxk.jwk, plainDataJson)\r\n    );\r\n\r\n    return {\r\n      sigPxkId: sigPxk.id,\r\n      publicDataSig,\r\n      publicSearchableSig,\r\n      plainDataSig,\r\n    };\r\n  }\r\n\r\n  private async createContactCard(\r\n    contactCard: MainContactCardFields\r\n  ): Promise<ApiContactCard> {\r\n    const input = await this.prepareContactCardInput(contactCard);\r\n\r\n    const { rootKey, cipherMeta } = await this.keyMetaService.wrapContent(\r\n      contactCard\r\n    );\r\n\r\n    const data = await this.lrApollo.mutate<{\r\n      createContactCard: { contactCard: ApiContactCard };\r\n    }>({\r\n      mutation: CreateContactCardMutation,\r\n      variables: {\r\n        input: {\r\n          ...input,\r\n          cipherData: cipherMeta,\r\n          wrappingKeyId: rootKey.wrappingKeyId,\r\n          wrappedKey: rootKey.wrappedKey,\r\n          default: true, // Use this contact card as default contact card.\r\n        },\r\n      },\r\n    });\r\n    return data.createContactCard.contactCard;\r\n  }\r\n\r\n  private async updateContactCard(\r\n    id: string,\r\n    keyId: string,\r\n    contactCard: MainContactCardFields\r\n  ): Promise<ApiContactCard> {\r\n    const input = await this.prepareContactCardInput(contactCard);\r\n\r\n    const cipherData = await this.keyGraph.encryptToString(keyId, contactCard);\r\n\r\n    const data = await this.lrApollo.mutate<{\r\n      updateContactCard: { contactCard: ApiContactCard };\r\n    }>({\r\n      mutation: UpdateContactCardMutation,\r\n      variables: {\r\n        input: {\r\n          ...input,\r\n          id,\r\n          cipherData,\r\n        },\r\n      },\r\n    });\r\n    return data.updateContactCard.contactCard;\r\n  }\r\n\r\n  async decryptContactCardEdges(edges): Promise<ContactCard[]> {\r\n    return Promise.all(\r\n      edges.map(async (edge: any) => {\r\n        const cc = edge.node as ContactCard;\r\n        return await this.decryptContactCard(cc);\r\n      })\r\n    );\r\n  }\r\n\r\n  async getContactCards(): Promise<ContactCard[]> {\r\n    const data = await this.lrApollo.query<any>({\r\n      query: ContactCardListQuery,\r\n    });\r\n\r\n    return await this.decryptContactCardEdges(data.contactCards.edges);\r\n  }\r\n\r\n  async deleteContactCard(id: string): Promise<string> {\r\n    const data = await this.lrApollo.mutate<any>({\r\n      mutation: DeleteContactCardMutation,\r\n      variables: {\r\n        input: {\r\n          id,\r\n        },\r\n      },\r\n    });\r\n\r\n    return data.deleteContactCard.id;\r\n  }\r\n\r\n  async signOut(): Promise<void> {\r\n    await this.http\r\n      .post(`${this.config.authUrl}auth/sign-out/`, null, {\r\n        withCredentials: true,\r\n        responseType: 'text',\r\n      })\r\n      .toPromise();\r\n  }\r\n}\r\n"]}
|