@lifeready/core 1.0.1 → 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/bundles/lifeready-core.umd.js +15939 -0
- package/bundles/lifeready-core.umd.js.map +1 -0
- package/bundles/lifeready-core.umd.min.js +16 -0
- package/bundles/lifeready-core.umd.min.js.map +1 -0
- package/esm2015/lib/_common/ast.js +40 -0
- package/esm2015/lib/_common/deferred-promise.js +24 -0
- package/esm2015/lib/_common/exceptions.js +157 -0
- package/esm2015/lib/_common/queries.gql.js +190 -0
- package/esm2015/lib/_common/run-outside-angular.js +79 -0
- package/esm2015/lib/_common/types.js +1 -0
- package/esm2015/lib/_common/utils.js +44 -0
- package/esm2015/lib/api/contact-card.gql.js +79 -0
- package/esm2015/lib/api/contact-card.service.js +154 -0
- package/esm2015/lib/api/contact-card2.gql.js +60 -0
- package/esm2015/lib/api/contact-card2.service.js +103 -0
- package/esm2015/lib/api/file.service.js +74 -0
- package/esm2015/lib/api/item2.gql.js +110 -0
- package/esm2015/lib/api/item2.service.js +311 -0
- package/esm2015/lib/api/key-exchange.gql.js +188 -0
- package/esm2015/lib/api/key-exchange.service.js +442 -0
- package/esm2015/lib/api/key-exchange.types.js +18 -0
- package/esm2015/lib/api/key-exchange2.gql.js +171 -0
- package/esm2015/lib/api/key-exchange2.service.js +479 -0
- package/esm2015/lib/api/lock.gql.js +40 -0
- package/esm2015/lib/api/lock.service.js +64 -0
- package/esm2015/lib/api/lr-apollo.service.js +46 -0
- package/esm2015/lib/api/lr-graphql/index.js +6 -0
- package/esm2015/lib/api/lr-graphql/lr-graphql.service.js +155 -0
- package/esm2015/lib/api/lr-graphql/lr-merged-mutation.js +213 -0
- package/esm2015/lib/api/lr-graphql/lr-mutation-base.js +51 -0
- package/esm2015/lib/api/lr-graphql/lr-mutation.js +48 -0
- package/esm2015/lib/api/lr-graphql/lr.service.js +18 -0
- package/esm2015/lib/api/message.service.js +138 -0
- package/esm2015/lib/api/persist.service.js +181 -0
- package/esm2015/lib/api/query-processor/common-processors.service.js +93 -0
- package/esm2015/lib/api/query-processor/index.js +3 -0
- package/esm2015/lib/api/query-processor/query-processor.service.js +192 -0
- package/esm2015/lib/api/query-processor/tp-password-reset-processor.service.js +109 -0
- package/esm2015/lib/api/shared-contact-card.service.js +119 -0
- package/esm2015/lib/api/shared-contact-card2.gql.js +41 -0
- package/esm2015/lib/api/shared-contact-card2.service.js +117 -0
- package/esm2015/lib/api/time.service.js +146 -0
- package/esm2015/lib/api/types/graphql.types.js +7 -0
- package/esm2015/lib/api/types/index.js +3 -0
- package/esm2015/lib/api/types/lr-graphql.types.js +71 -0
- package/esm2015/lib/auth/auth.config.js +57 -0
- package/esm2015/lib/auth/auth.gql.js +48 -0
- package/esm2015/lib/auth/auth.types.js +27 -0
- package/esm2015/lib/auth/idle.service.js +168 -0
- package/esm2015/lib/auth/idle.types.js +7 -0
- package/esm2015/lib/auth/lbop.service.js +355 -0
- package/esm2015/lib/auth/life-ready-auth.service.js +500 -0
- package/esm2015/lib/auth/password.service.js +320 -0
- package/esm2015/lib/auth/register.service.js +172 -0
- package/esm2015/lib/auth/two-factor.service.js +74 -0
- package/esm2015/lib/category/category-meta.service.js +99 -0
- package/esm2015/lib/category/category.gql.js +406 -0
- package/esm2015/lib/category/category.service.js +390 -0
- package/esm2015/lib/category/category.types.js +29 -0
- package/esm2015/lib/cryptography/cryptography.types.js +11 -0
- package/esm2015/lib/cryptography/encryption.service.js +189 -0
- package/esm2015/lib/cryptography/key-factory.service.js +237 -0
- package/esm2015/lib/cryptography/key-graph.service.js +280 -0
- package/esm2015/lib/cryptography/key-meta.service.js +200 -0
- package/esm2015/lib/cryptography/key.service.js +124 -0
- package/esm2015/lib/cryptography/slip39.service.js +169 -0
- package/esm2015/lib/cryptography/web-crypto.service.js +29 -0
- package/esm2015/lib/life-ready.config.js +84 -0
- package/esm2015/lib/life-ready.module.js +74 -0
- package/esm2015/lib/plan/plan.gql.js +123 -0
- package/esm2015/lib/plan/plan.service.js +149 -0
- package/esm2015/lib/plan/plan.types.js +11 -0
- package/esm2015/lib/record/record-attachment.service.js +101 -0
- package/esm2015/lib/record/record.gql.js +179 -0
- package/esm2015/lib/record/record.service.js +206 -0
- package/esm2015/lib/record/record.types.js +15 -0
- package/esm2015/lib/record-type/record-type.service.js +75 -0
- package/esm2015/lib/record-type/record-type.types.js +28 -0
- package/esm2015/lib/scenario/approvals/scenario-approval.gql.js +105 -0
- package/esm2015/lib/scenario/approvals/scenario-approval.types.js +1 -0
- package/esm2015/lib/scenario/approvals/scenario-approver.service.js +300 -0
- package/esm2015/lib/scenario/claimants/scenario-claimant.gql.js +52 -0
- package/esm2015/lib/scenario/claimants/scenario-claimant.service.js +97 -0
- package/esm2015/lib/scenario/claimants/scenario-claimant.types.js +1 -0
- package/esm2015/lib/scenario/receivers/scenario-receiver.gql.js +150 -0
- package/esm2015/lib/scenario/receivers/scenario-receiver.service.js +229 -0
- package/esm2015/lib/scenario/receivers/scenario-receiver.types.js +1 -0
- package/esm2015/lib/scenario/scenario-setup.service.js +269 -0
- package/esm2015/lib/scenario/scenario.gql.js +368 -0
- package/esm2015/lib/scenario/scenario.service.js +611 -0
- package/esm2015/lib/scenario/scenario.types.js +64 -0
- package/esm2015/lib/search/search.gql.js +62 -0
- package/esm2015/lib/search/search.service.js +156 -0
- package/esm2015/lib/search/search.types.js +6 -0
- package/esm2015/lib/trusted-parties/tp-password-reset-request.service.js +112 -0
- package/esm2015/lib/trusted-parties/tp-password-reset-user.service.js +129 -0
- package/esm2015/lib/trusted-parties/tp-password-reset.constants.js +4 -0
- package/esm2015/lib/trusted-parties/tp-password-reset.gql.js +232 -0
- package/esm2015/lib/trusted-parties/tp-password-reset.service.js +299 -0
- package/esm2015/lib/trusted-parties/trusted-party.gql.js +148 -0
- package/esm2015/lib/trusted-parties/trusted-party.service.js +326 -0
- package/esm2015/lib/trusted-parties/trusted-party.types.js +41 -0
- package/esm2015/lib/trusted-parties/trusted-party2.gql.js +87 -0
- package/esm2015/lib/trusted-parties/trusted-party2.service.js +215 -0
- package/esm2015/lib/users/profile-details.service.js +214 -0
- package/esm2015/lib/users/profile.gql.js +97 -0
- package/esm2015/lib/users/profile.service.js +169 -0
- package/esm2015/lib/users/profile.types.js +34 -0
- package/esm2015/lib/users/user.gql.js +60 -0
- package/esm2015/lib/users/user.service.js +79 -0
- package/esm2015/lib/users/user.types.js +5 -0
- package/esm2015/lifeready-core.js +10 -0
- package/esm2015/public-api.js +81 -0
- package/fesm2015/lifeready-core.js +13314 -0
- package/fesm2015/lifeready-core.js.map +1 -0
- package/lib/_common/ast.d.ts +11 -0
- package/lib/_common/deferred-promise.d.ts +12 -0
- package/lib/_common/exceptions.d.ts +109 -0
- package/lib/_common/queries.gql.d.ts +10 -0
- package/lib/_common/run-outside-angular.d.ts +14 -0
- package/{src/lib/_common/types.ts → lib/_common/types.d.ts} +3 -6
- package/lib/_common/utils.d.ts +3 -0
- package/lib/api/contact-card.gql.d.ts +7 -0
- package/lib/api/contact-card.service.d.ts +52 -0
- package/lib/api/contact-card2.gql.d.ts +34 -0
- package/lib/api/contact-card2.service.d.ts +49 -0
- package/lib/api/file.service.d.ts +18 -0
- package/lib/api/item2.gql.d.ts +96 -0
- package/lib/api/item2.service.d.ts +177 -0
- package/lib/api/key-exchange.gql.d.ts +9 -0
- package/lib/api/key-exchange.service.d.ts +39 -0
- package/lib/api/key-exchange.types.d.ts +196 -0
- package/lib/api/key-exchange2.gql.d.ts +125 -0
- package/lib/api/key-exchange2.service.d.ts +187 -0
- package/lib/api/lock.gql.d.ts +27 -0
- package/lib/api/lock.service.d.ts +25 -0
- package/lib/api/lr-apollo.service.d.ts +15 -0
- package/lib/api/lr-graphql/lr-graphql.service.d.ts +60 -0
- package/lib/api/lr-graphql/lr-merged-mutation.d.ts +27 -0
- package/lib/api/lr-graphql/lr-mutation-base.d.ts +28 -0
- package/lib/api/lr-graphql/lr-mutation.d.ts +8 -0
- package/lib/api/lr-graphql/lr.service.d.ts +9 -0
- package/lib/api/message.service.d.ts +58 -0
- package/lib/api/persist.service.d.ts +31 -0
- package/lib/api/query-processor/common-processors.service.d.ts +36 -0
- package/lib/api/query-processor/query-processor.service.d.ts +18 -0
- package/lib/api/query-processor/tp-password-reset-processor.service.d.ts +15 -0
- package/lib/api/shared-contact-card.service.d.ts +33 -0
- package/lib/api/shared-contact-card2.gql.d.ts +36 -0
- package/lib/api/shared-contact-card2.service.d.ts +45 -0
- package/lib/api/time.service.d.ts +16 -0
- package/lib/api/types/graphql.types.d.ts +29 -0
- package/lib/api/types/lr-graphql.types.d.ts +385 -0
- package/lib/auth/auth.config.d.ts +5 -0
- package/lib/auth/auth.gql.d.ts +15 -0
- package/lib/auth/auth.types.d.ts +66 -0
- package/lib/auth/idle.service.d.ts +40 -0
- package/lib/auth/idle.types.d.ts +10 -0
- package/lib/auth/lbop.service.d.ts +91 -0
- package/lib/auth/life-ready-auth.service.d.ts +59 -0
- package/lib/auth/password.service.d.ts +78 -0
- package/lib/auth/register.service.d.ts +25 -0
- package/lib/auth/two-factor.service.d.ts +15 -0
- package/lib/category/category-meta.service.d.ts +23 -0
- package/lib/category/category.gql.d.ts +45 -0
- package/lib/category/category.service.d.ts +67 -0
- package/lib/category/category.types.d.ts +79 -0
- package/lib/cryptography/cryptography.types.d.ts +83 -0
- package/lib/cryptography/encryption.service.d.ts +41 -0
- package/lib/cryptography/key-factory.service.d.ts +38 -0
- package/lib/cryptography/key-graph.service.d.ts +33 -0
- package/lib/cryptography/key-meta.service.d.ts +44 -0
- package/lib/cryptography/key.service.d.ts +36 -0
- package/lib/cryptography/slip39.service.d.ts +43 -0
- package/lib/cryptography/web-crypto.service.d.ts +5 -0
- package/lib/life-ready.config.d.ts +14 -0
- package/lib/life-ready.module.d.ts +5 -0
- package/lib/plan/plan.gql.d.ts +11 -0
- package/lib/plan/plan.service.d.ts +33 -0
- package/lib/plan/plan.types.d.ts +31 -0
- package/lib/record/record-attachment.service.d.ts +16 -0
- package/lib/record/record.gql.d.ts +14 -0
- package/lib/record/record.service.d.ts +25 -0
- package/lib/record/record.types.d.ts +57 -0
- package/lib/record-type/record-type.service.d.ts +11 -0
- package/lib/record-type/record-type.types.d.ts +50 -0
- package/lib/scenario/approvals/scenario-approval.gql.d.ts +7 -0
- package/lib/scenario/approvals/scenario-approval.types.d.ts +63 -0
- package/lib/scenario/approvals/scenario-approver.service.d.ts +32 -0
- package/lib/scenario/claimants/scenario-claimant.gql.d.ts +5 -0
- package/lib/scenario/claimants/scenario-claimant.service.d.ts +17 -0
- package/lib/scenario/claimants/scenario-claimant.types.d.ts +18 -0
- package/lib/scenario/receivers/scenario-receiver.gql.d.ts +8 -0
- package/lib/scenario/receivers/scenario-receiver.service.d.ts +30 -0
- package/lib/scenario/receivers/scenario-receiver.types.d.ts +54 -0
- package/lib/scenario/scenario-setup.service.d.ts +22 -0
- package/lib/scenario/scenario.gql.d.ts +34 -0
- package/lib/scenario/scenario.service.d.ts +58 -0
- package/lib/scenario/scenario.types.d.ts +217 -0
- package/lib/search/search.gql.d.ts +1 -0
- package/lib/search/search.service.d.ts +25 -0
- package/lib/search/search.types.d.ts +20 -0
- package/lib/trusted-parties/tp-password-reset-request.service.d.ts +20 -0
- package/lib/trusted-parties/tp-password-reset-user.service.d.ts +35 -0
- package/lib/trusted-parties/tp-password-reset.constants.d.ts +3 -0
- package/lib/trusted-parties/tp-password-reset.gql.d.ts +218 -0
- package/lib/trusted-parties/tp-password-reset.service.d.ts +130 -0
- package/lib/trusted-parties/trusted-party.gql.d.ts +9 -0
- package/lib/trusted-parties/trusted-party.service.d.ts +44 -0
- package/lib/trusted-parties/trusted-party.types.d.ts +102 -0
- package/lib/trusted-parties/trusted-party2.gql.d.ts +79 -0
- package/lib/trusted-parties/trusted-party2.service.d.ts +114 -0
- package/lib/users/profile-details.service.d.ts +21 -0
- package/lib/users/profile.gql.d.ts +11 -0
- package/lib/users/profile.service.d.ts +35 -0
- package/lib/users/profile.types.d.ts +96 -0
- package/lib/users/user.gql.d.ts +9 -0
- package/lib/users/user.service.d.ts +12 -0
- package/lib/users/user.types.d.ts +23 -0
- package/lifeready-core.d.ts +9 -0
- package/lifeready-core.metadata.json +1 -0
- package/package.json +29 -21
- package/{src/public-api.ts → public-api.d.ts} +0 -19
- package/karma.conf.js +0 -32
- package/ng-package.json +0 -26
- package/src/lib/_common/ast.ts +0 -75
- package/src/lib/_common/deferred-promise.ts +0 -35
- package/src/lib/_common/exceptions.ts +0 -189
- package/src/lib/_common/queries.gql.ts +0 -200
- package/src/lib/_common/run-outside-angular.ts +0 -125
- package/src/lib/_common/tests.ts +0 -82
- package/src/lib/_common/utils.ts +0 -57
- package/src/lib/api/api-mutation.spec.ts +0 -547
- package/src/lib/api/api-query.spec.ts +0 -40
- package/src/lib/api/contact-card.gql.ts +0 -85
- package/src/lib/api/contact-card.service.spec.ts +0 -249
- package/src/lib/api/contact-card.service.ts +0 -228
- package/src/lib/api/contact-card2.gql.ts +0 -93
- package/src/lib/api/contact-card2.service.spec.ts +0 -297
- package/src/lib/api/contact-card2.service.ts +0 -139
- package/src/lib/api/file.service.spec.ts +0 -14
- package/src/lib/api/file.service.ts +0 -81
- package/src/lib/api/item2.gql.ts +0 -211
- package/src/lib/api/item2.service.spec.ts +0 -1043
- package/src/lib/api/item2.service.ts +0 -481
- package/src/lib/api/key-exchange.gql.ts +0 -196
- package/src/lib/api/key-exchange.service.spec.ts +0 -470
- package/src/lib/api/key-exchange.service.ts +0 -731
- package/src/lib/api/key-exchange.types.ts +0 -235
- package/src/lib/api/key-exchange2.gql.ts +0 -310
- package/src/lib/api/key-exchange2.service.spec.ts +0 -892
- package/src/lib/api/key-exchange2.service.ts +0 -875
- package/src/lib/api/lock.gql.ts +0 -67
- package/src/lib/api/lock.service.spec.ts +0 -549
- package/src/lib/api/lock.service.ts +0 -57
- package/src/lib/api/lr-apollo.service.spec.ts +0 -27
- package/src/lib/api/lr-apollo.service.ts +0 -43
- package/src/lib/api/lr-graphql/lr-graphql.service.ts +0 -313
- package/src/lib/api/lr-graphql/lr-merged-mutation.ts +0 -377
- package/src/lib/api/lr-graphql/lr-mutation-base.ts +0 -67
- package/src/lib/api/lr-graphql/lr-mutation.ts +0 -74
- package/src/lib/api/lr-graphql/lr.service.ts +0 -28
- package/src/lib/api/message.service.spec.ts +0 -20
- package/src/lib/api/message.service.ts +0 -210
- package/src/lib/api/persist.service.spec.ts +0 -209
- package/src/lib/api/persist.service.ts +0 -220
- package/src/lib/api/query-processor/common-processors.service.ts +0 -148
- package/src/lib/api/query-processor/query-processor.service.ts +0 -240
- package/src/lib/api/query-processor/tp-password-reset-processor.service.ts +0 -177
- package/src/lib/api/shared-contact-card.service.ts +0 -156
- package/src/lib/api/shared-contact-card2.gql.ts +0 -76
- package/src/lib/api/shared-contact-card2.service.ts +0 -154
- package/src/lib/api/time.service.spec.ts +0 -48
- package/src/lib/api/time.service.ts +0 -155
- package/src/lib/api/types/graphql.types.ts +0 -48
- package/src/lib/api/types/lr-graphql.types.ts +0 -467
- package/src/lib/auth/auth.config.ts +0 -83
- package/src/lib/auth/auth.gql.ts +0 -62
- package/src/lib/auth/auth.types.ts +0 -79
- package/src/lib/auth/idle.service.spec.ts +0 -119
- package/src/lib/auth/idle.service.ts +0 -208
- package/src/lib/auth/idle.types.ts +0 -11
- package/src/lib/auth/lbop.service.spec.ts +0 -56
- package/src/lib/auth/lbop.service.ts +0 -539
- package/src/lib/auth/life-ready-auth.service.spec.ts +0 -70
- package/src/lib/auth/life-ready-auth.service.ts +0 -454
- package/src/lib/auth/password.service.spec.ts +0 -51
- package/src/lib/auth/password.service.ts +0 -438
- package/src/lib/auth/register.service.spec.ts +0 -31
- package/src/lib/auth/register.service.ts +0 -181
- package/src/lib/auth/two-factor.service.spec.ts +0 -21
- package/src/lib/auth/two-factor.service.ts +0 -69
- package/src/lib/category/category-meta.service.spec.ts +0 -28
- package/src/lib/category/category-meta.service.ts +0 -125
- package/src/lib/category/category.gql.ts +0 -449
- package/src/lib/category/category.service.spec.ts +0 -26
- package/src/lib/category/category.service.ts +0 -498
- package/src/lib/category/category.types.ts +0 -89
- package/src/lib/cryptography/cryptography.types.ts +0 -108
- package/src/lib/cryptography/encryption.service.spec.ts +0 -125
- package/src/lib/cryptography/encryption.service.ts +0 -243
- package/src/lib/cryptography/key-factory.service.spec.ts +0 -15
- package/src/lib/cryptography/key-factory.service.ts +0 -303
- package/src/lib/cryptography/key-graph.service.spec.ts +0 -16
- package/src/lib/cryptography/key-graph.service.ts +0 -354
- package/src/lib/cryptography/key-meta.service.spec.ts +0 -40
- package/src/lib/cryptography/key-meta.service.ts +0 -254
- package/src/lib/cryptography/key.service.spec.ts +0 -16
- package/src/lib/cryptography/key.service.ts +0 -154
- package/src/lib/cryptography/slip39.service.spec.ts +0 -44
- package/src/lib/cryptography/slip39.service.ts +0 -204
- package/src/lib/cryptography/web-crypto.service.ts +0 -22
- package/src/lib/life-ready.config.ts +0 -127
- package/src/lib/life-ready.module.ts +0 -81
- package/src/lib/plan/plan.gql.ts +0 -133
- package/src/lib/plan/plan.service.spec.ts +0 -294
- package/src/lib/plan/plan.service.ts +0 -198
- package/src/lib/plan/plan.types.ts +0 -37
- package/src/lib/record/record-attachment.service.spec.ts +0 -31
- package/src/lib/record/record-attachment.service.ts +0 -101
- package/src/lib/record/record.gql.ts +0 -192
- package/src/lib/record/record.service.spec.ts +0 -598
- package/src/lib/record/record.service.ts +0 -236
- package/src/lib/record/record.types.ts +0 -86
- package/src/lib/record-type/record-type.service.spec.ts +0 -16
- package/src/lib/record-type/record-type.service.ts +0 -71
- package/src/lib/record-type/record-type.types.ts +0 -58
- package/src/lib/scenario/approvals/scenario-approval.gql.ts +0 -112
- package/src/lib/scenario/approvals/scenario-approval.types.ts +0 -85
- package/src/lib/scenario/approvals/scenario-approver.service.spec.ts +0 -16
- package/src/lib/scenario/approvals/scenario-approver.service.ts +0 -422
- package/src/lib/scenario/claimants/scenario-claimant.gql.ts +0 -56
- package/src/lib/scenario/claimants/scenario-claimant.service.spec.ts +0 -16
- package/src/lib/scenario/claimants/scenario-claimant.service.ts +0 -100
- package/src/lib/scenario/claimants/scenario-claimant.types.ts +0 -21
- package/src/lib/scenario/receivers/scenario-receiver.gql.ts +0 -157
- package/src/lib/scenario/receivers/scenario-receiver.service.spec.ts +0 -16
- package/src/lib/scenario/receivers/scenario-receiver.service.ts +0 -278
- package/src/lib/scenario/receivers/scenario-receiver.types.ts +0 -66
- package/src/lib/scenario/scenario-setup.service.spec.ts +0 -22
- package/src/lib/scenario/scenario-setup.service.ts +0 -369
- package/src/lib/scenario/scenario.gql.ts +0 -404
- package/src/lib/scenario/scenario.service.spec.ts +0 -1586
- package/src/lib/scenario/scenario.service.ts +0 -811
- package/src/lib/scenario/scenario.types.ts +0 -258
- package/src/lib/search/search.gql.ts +0 -62
- package/src/lib/search/search.service.spec.ts +0 -57
- package/src/lib/search/search.service.ts +0 -174
- package/src/lib/search/search.types.ts +0 -24
- package/src/lib/trusted-parties/tp-password-reset-request.service.ts +0 -140
- package/src/lib/trusted-parties/tp-password-reset-user.service.ts +0 -359
- package/src/lib/trusted-parties/tp-password-reset.gql.ts +0 -453
- package/src/lib/trusted-parties/tp-password-reset.service.spec.ts +0 -602
- package/src/lib/trusted-parties/tp-password-reset.service.ts +0 -482
- package/src/lib/trusted-parties/trusted-party.gql.ts +0 -159
- package/src/lib/trusted-parties/trusted-party.service.spec.ts +0 -1008
- package/src/lib/trusted-parties/trusted-party.service.ts +0 -394
- package/src/lib/trusted-parties/trusted-party.types.ts +0 -119
- package/src/lib/trusted-parties/trusted-party2.gql.ts +0 -165
- package/src/lib/trusted-parties/trusted-party2.service.spec.ts +0 -1782
- package/src/lib/trusted-parties/trusted-party2.service.ts +0 -272
- package/src/lib/users/profile-details.service.spec.ts +0 -45
- package/src/lib/users/profile-details.service.ts +0 -278
- package/src/lib/users/profile.gql.ts +0 -108
- package/src/lib/users/profile.service.spec.ts +0 -97
- package/src/lib/users/profile.service.ts +0 -224
- package/src/lib/users/profile.types.ts +0 -101
- package/src/lib/users/user.gql.ts +0 -69
- package/src/lib/users/user.service.spec.ts +0 -161
- package/src/lib/users/user.service.ts +0 -72
- package/src/lib/users/user.types.ts +0 -27
- package/src/test.ts +0 -21
- package/tsconfig.lib.json +0 -21
- package/tsconfig.lib.prod.json +0 -6
- package/tsconfig.spec.json +0 -10
- package/tslint.json +0 -17
- /package/{src/lib/api/lr-graphql/index.ts → lib/api/lr-graphql/index.d.ts} +0 -0
- /package/{src/lib/api/query-processor/index.ts → lib/api/query-processor/index.d.ts} +0 -0
- /package/{src/lib/api/types/index.ts → lib/api/types/index.d.ts} +0 -0
|
@@ -0,0 +1,168 @@
|
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
2
|
+
import { Inject, Injectable } from '@angular/core';
|
|
3
|
+
import { Idle, DEFAULT_INTERRUPTSOURCES } from '@ng-idle/core';
|
|
4
|
+
import { Keepalive } from '@ng-idle/keepalive';
|
|
5
|
+
import { KeyService } from '../cryptography/key.service';
|
|
6
|
+
import { LrBadArgumentException, LrBadStateException, } from '../_common/exceptions';
|
|
7
|
+
import { LR_CONFIG } from '../life-ready.config';
|
|
8
|
+
import { HttpClient } from '@angular/common/http';
|
|
9
|
+
import { Config } from './idle.types';
|
|
10
|
+
import { AuthClass } from '@aws-amplify/auth/lib-esm/Auth';
|
|
11
|
+
import * as i0 from "@angular/core";
|
|
12
|
+
import * as i1 from "../life-ready.config";
|
|
13
|
+
import * as i2 from "@angular/common/http";
|
|
14
|
+
import * as i3 from "@ng-idle/core";
|
|
15
|
+
import * as i4 from "@ng-idle/keepalive";
|
|
16
|
+
import * as i5 from "../cryptography/key.service";
|
|
17
|
+
import * as i6 from "@aws-amplify/auth/lib-esm/Auth";
|
|
18
|
+
export class IdleService {
|
|
19
|
+
constructor(config, http, idle, keepalive, keyService, auth) {
|
|
20
|
+
this.config = config;
|
|
21
|
+
this.http = http;
|
|
22
|
+
this.idle = idle;
|
|
23
|
+
this.keepalive = keepalive;
|
|
24
|
+
this.keyService = keyService;
|
|
25
|
+
this.auth = auth;
|
|
26
|
+
this.IDLE_EXPIRY_KEY = 'ng2Idle.main.expiry';
|
|
27
|
+
this.IDLING_KEY = 'ng2Idle.main.idling';
|
|
28
|
+
this.initCalled = false;
|
|
29
|
+
}
|
|
30
|
+
assertInit() {
|
|
31
|
+
if (!this.initCalled) {
|
|
32
|
+
throw new LrBadStateException('Call IdleService.init() first.');
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
init(params) {
|
|
36
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
37
|
+
if (this.initCalled) {
|
|
38
|
+
throw new LrBadStateException('IdleService.init() can only be called once. IdleService.start() calls init() with default values if init() has not been called yet.');
|
|
39
|
+
}
|
|
40
|
+
this.initCalled = true;
|
|
41
|
+
// Defaults
|
|
42
|
+
params = Object.assign({ onTimeout: null, onKeepalive: null, idleSec: Config.IDLE, timeoutSec: Config.TIMEOUT, keepAliveIntervalSec: Config.KEEP_ALIVE_INTERVAL }, params);
|
|
43
|
+
// If timeoutSec == 0 then the onTimeout() callback is never called.
|
|
44
|
+
if (params.timeoutSec < 0.01) {
|
|
45
|
+
throw new LrBadArgumentException('Minimum value for IdleService.init({ timeoutSec }) is 0.01');
|
|
46
|
+
}
|
|
47
|
+
this.onTimeout = params.onTimeout;
|
|
48
|
+
this.onKeepalive = params.onKeepalive;
|
|
49
|
+
// ------------------------------------------------------------------------
|
|
50
|
+
// Setup Idle
|
|
51
|
+
// ------------------------------------------------------------------------
|
|
52
|
+
// sets an idle timeout of 5 seconds, for testing purposes.
|
|
53
|
+
this.idle.setIdle(params.idleSec);
|
|
54
|
+
// sets a timeout period of 5 seconds. after 10 seconds of inactivity, the user will be considered timed out.
|
|
55
|
+
this.idle.setTimeout(params.timeoutSec);
|
|
56
|
+
// sets the default interrupts, in this case, things like clicks, scrolls, touches to the document
|
|
57
|
+
this.idle.setInterrupts(DEFAULT_INTERRUPTSOURCES);
|
|
58
|
+
this.idle.onIdleEnd.subscribe(() => console.log('Idle stopped'));
|
|
59
|
+
this.idle.onIdleStart.subscribe(() => console.log('Idle started'));
|
|
60
|
+
this.idle.onTimeout.subscribe(() => __awaiter(this, void 0, void 0, function* () {
|
|
61
|
+
console.log('Idle timed out');
|
|
62
|
+
this.reset();
|
|
63
|
+
yield Promise.resolve(this.onTimeout && this.onTimeout());
|
|
64
|
+
}));
|
|
65
|
+
this.idle.onTimeoutWarning.subscribe((countdown) => console.log(`Will timeout in ${countdown} seconds!`));
|
|
66
|
+
// ------------------------------------------------------------------------
|
|
67
|
+
// Setup Keepalive
|
|
68
|
+
// ------------------------------------------------------------------------
|
|
69
|
+
// Ref: https://github.com/moribvndvs/ng2-idle#readme
|
|
70
|
+
// ng-idle will instruct @ng-idle/keepalive to ping while the user is active, and stop once
|
|
71
|
+
// they go idle or time out. When the user resumes activity or the idle state is reset, it will
|
|
72
|
+
// ping immediately and then resume pinging.
|
|
73
|
+
this.keepalive.interval(params.keepAliveIntervalSec);
|
|
74
|
+
console.log(`Keep alive interval set at: ${Config.KEEP_ALIVE_INTERVAL} seconds`);
|
|
75
|
+
this.keepalive.onPing.subscribe(() => this.onPing());
|
|
76
|
+
// If the browser tab has been closed for a period longer thant the inactivity
|
|
77
|
+
// period, then we should logout right from the start.
|
|
78
|
+
const idleExpiry = localStorage.getItem(this.IDLE_EXPIRY_KEY);
|
|
79
|
+
if (idleExpiry &&
|
|
80
|
+
parseInt(idleExpiry, 10) + this.idle.getTimeout() * 1000 < Date.now()) {
|
|
81
|
+
this.reset();
|
|
82
|
+
yield Promise.resolve(this.onTimeout && this.onTimeout());
|
|
83
|
+
}
|
|
84
|
+
});
|
|
85
|
+
}
|
|
86
|
+
keepalivePost() {
|
|
87
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
88
|
+
// currentAuthenticatedUser() refreshes the access token if required.
|
|
89
|
+
const cognitoUser = yield this.auth.currentAuthenticatedUser();
|
|
90
|
+
const keepaliveResult = yield this.http
|
|
91
|
+
.post(`${this.config.authUrl}auth/keepalive/`, null, {
|
|
92
|
+
withCredentials: true,
|
|
93
|
+
headers: {
|
|
94
|
+
Authorization: `Bearer ${cognitoUser
|
|
95
|
+
.getSignInUserSession()
|
|
96
|
+
.getAccessToken()
|
|
97
|
+
.getJwtToken()}`,
|
|
98
|
+
},
|
|
99
|
+
})
|
|
100
|
+
.toPromise();
|
|
101
|
+
return {
|
|
102
|
+
keepaliveResult,
|
|
103
|
+
expiresAfterSeconds: this.idle.getIdle() +
|
|
104
|
+
this.idle.getTimeout() +
|
|
105
|
+
this.keepalive.interval(),
|
|
106
|
+
};
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
persistMasterKey(masterKey) {
|
|
110
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
111
|
+
// The keepalive API call extends the server-side session, the session cookie expiry, refresh key cookie
|
|
112
|
+
// expiry, and returns the session expiry.
|
|
113
|
+
// NOTE Use time delta rather than absolute time, since client clock and server clock maybe
|
|
114
|
+
// out of sync. We can't use the serverTime() functionality because the cookie expiry still
|
|
115
|
+
// run on local clock.
|
|
116
|
+
const { expiresAfterSeconds } = yield this.keepalivePost();
|
|
117
|
+
// Persist the derived passKey
|
|
118
|
+
yield this.keyService.persistMasterKey(masterKey, expiresAfterSeconds);
|
|
119
|
+
console.log('setMasterKey() done');
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
onPing() {
|
|
123
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
124
|
+
console.log(`Keep alive triggered at time: ${Date.now()}. Interval set at: ${this.keepalive.interval()} seconds`);
|
|
125
|
+
// Keepalive API will extend the session expiry.
|
|
126
|
+
const { expiresAfterSeconds } = yield this.keepalivePost();
|
|
127
|
+
// Extend the expiry of the persisted key
|
|
128
|
+
yield this.keyService.setMasterKeyExpiresAfterSeconds(expiresAfterSeconds);
|
|
129
|
+
yield Promise.resolve(this.onKeepalive && this.onKeepalive());
|
|
130
|
+
});
|
|
131
|
+
}
|
|
132
|
+
start() {
|
|
133
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
134
|
+
if (!this.initCalled) {
|
|
135
|
+
yield this.init();
|
|
136
|
+
}
|
|
137
|
+
if (this.idle.isRunning()) {
|
|
138
|
+
return;
|
|
139
|
+
}
|
|
140
|
+
// Ping does not seem to happen right at the start. So we call it explicitly
|
|
141
|
+
yield this.onPing();
|
|
142
|
+
this.idle.watch();
|
|
143
|
+
});
|
|
144
|
+
}
|
|
145
|
+
stop() {
|
|
146
|
+
this.idle.stop();
|
|
147
|
+
this.reset();
|
|
148
|
+
}
|
|
149
|
+
reset() {
|
|
150
|
+
localStorage.removeItem(this.IDLE_EXPIRY_KEY);
|
|
151
|
+
localStorage.removeItem(this.IDLING_KEY);
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
IdleService.ɵprov = i0.ɵɵdefineInjectable({ factory: function IdleService_Factory() { return new IdleService(i0.ɵɵinject(i1.LR_CONFIG), i0.ɵɵinject(i2.HttpClient), i0.ɵɵinject(i3.Idle), i0.ɵɵinject(i4.Keepalive), i0.ɵɵinject(i5.KeyService), i0.ɵɵinject(i6.AuthClass)); }, token: IdleService, providedIn: "root" });
|
|
155
|
+
IdleService.decorators = [
|
|
156
|
+
{ type: Injectable, args: [{
|
|
157
|
+
providedIn: 'root',
|
|
158
|
+
},] }
|
|
159
|
+
];
|
|
160
|
+
IdleService.ctorParameters = () => [
|
|
161
|
+
{ type: undefined, decorators: [{ type: Inject, args: [LR_CONFIG,] }] },
|
|
162
|
+
{ type: HttpClient },
|
|
163
|
+
{ type: Idle },
|
|
164
|
+
{ type: Keepalive },
|
|
165
|
+
{ type: KeyService },
|
|
166
|
+
{ type: AuthClass }
|
|
167
|
+
];
|
|
168
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"idle.service.js","sourceRoot":"C:/Projects/newrepo/kc-client/projects/core/src/","sources":["lib/auth/idle.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable } from '@angular/core';\r\nimport { Idle, DEFAULT_INTERRUPTSOURCES } from '@ng-idle/core';\r\nimport { Keepalive } from '@ng-idle/keepalive';\r\nimport { KeyService } from '../cryptography/key.service';\r\nimport {\r\n  LrBadArgumentException,\r\n  LrBadStateException,\r\n} from '../_common/exceptions';\r\nimport { LifeReadyConfig, LR_CONFIG } from '../life-ready.config';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { Config, KeepaliveResult } from './idle.types';\r\nimport { Key } from '../cryptography/cryptography.types';\r\nimport { CognitoUser } from '@aws-amplify/auth';\r\nimport { AuthClass } from '@aws-amplify/auth/lib-esm/Auth';\r\n\r\nexport interface IdleServiceInit {\r\n  // TODO: this should be EventEmitter instead of a callback.\r\n  onTimeout?: (() => any) | (() => Promise<any>) | null;\r\n  onKeepalive?: (() => any) | (() => Promise<any>) | null;\r\n  idleSec?: number;\r\n  timeoutSec?: number;\r\n  keepAliveIntervalSec?: number;\r\n}\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class IdleService {\r\n  private readonly IDLE_EXPIRY_KEY = 'ng2Idle.main.expiry';\r\n  private readonly IDLING_KEY = 'ng2Idle.main.idling';\r\n\r\n  private initCalled = false;\r\n  private onTimeout: (() => any) | (() => Promise<any>) | null;\r\n  private onKeepalive: (() => any) | (() => Promise<any>) | null;\r\n\r\n  constructor(\r\n    @Inject(LR_CONFIG) private config: LifeReadyConfig,\r\n    private http: HttpClient,\r\n    private idle: Idle,\r\n    private keepalive: Keepalive,\r\n    private keyService: KeyService,\r\n    private auth: AuthClass\r\n  ) {}\r\n\r\n  private assertInit(): void {\r\n    if (!this.initCalled) {\r\n      throw new LrBadStateException('Call IdleService.init() first.');\r\n    }\r\n  }\r\n\r\n  public async init(params?: IdleServiceInit): Promise<void> {\r\n    if (this.initCalled) {\r\n      throw new LrBadStateException(\r\n        'IdleService.init() can only be called once. IdleService.start() calls init() with default values if init() has not been called yet.'\r\n      );\r\n    }\r\n\r\n    this.initCalled = true;\r\n\r\n    // Defaults\r\n    params = {\r\n      onTimeout: null,\r\n      onKeepalive: null,\r\n      idleSec: Config.IDLE,\r\n      timeoutSec: Config.TIMEOUT,\r\n      keepAliveIntervalSec: Config.KEEP_ALIVE_INTERVAL,\r\n      ...params,\r\n    };\r\n\r\n    // If timeoutSec == 0 then the onTimeout() callback is never called.\r\n    if (params.timeoutSec < 0.01) {\r\n      throw new LrBadArgumentException(\r\n        'Minimum value for IdleService.init({ timeoutSec }) is 0.01'\r\n      );\r\n    }\r\n\r\n    this.onTimeout = params.onTimeout;\r\n    this.onKeepalive = params.onKeepalive;\r\n\r\n    // ------------------------------------------------------------------------\r\n    // Setup Idle\r\n    // ------------------------------------------------------------------------\r\n    // sets an idle timeout of 5 seconds, for testing purposes.\r\n    this.idle.setIdle(params.idleSec);\r\n    // sets a timeout period of 5 seconds. after 10 seconds of inactivity, the user will be considered timed out.\r\n    this.idle.setTimeout(params.timeoutSec);\r\n    // sets the default interrupts, in this case, things like clicks, scrolls, touches to the document\r\n    this.idle.setInterrupts(DEFAULT_INTERRUPTSOURCES);\r\n\r\n    this.idle.onIdleEnd.subscribe(() => console.log('Idle stopped'));\r\n    this.idle.onIdleStart.subscribe(() => console.log('Idle started'));\r\n\r\n    this.idle.onTimeout.subscribe(async () => {\r\n      console.log('Idle timed out');\r\n      this.reset();\r\n      await Promise.resolve(this.onTimeout && this.onTimeout());\r\n    });\r\n    this.idle.onTimeoutWarning.subscribe((countdown: any) =>\r\n      console.log(`Will timeout in ${countdown} seconds!`)\r\n    );\r\n\r\n    // ------------------------------------------------------------------------\r\n    // Setup Keepalive\r\n    // ------------------------------------------------------------------------\r\n    // Ref: https://github.com/moribvndvs/ng2-idle#readme\r\n    // ng-idle will instruct @ng-idle/keepalive to ping while the user is active, and stop once\r\n    // they go idle or time out. When the user resumes activity or the idle state is reset, it will\r\n    // ping immediately and then resume pinging.\r\n    this.keepalive.interval(params.keepAliveIntervalSec);\r\n    console.log(\r\n      `Keep alive interval set at: ${Config.KEEP_ALIVE_INTERVAL} seconds`\r\n    );\r\n\r\n    this.keepalive.onPing.subscribe(() => this.onPing());\r\n\r\n    // If the browser tab has been closed for a period longer thant the inactivity\r\n    // period, then we should logout right from the start.\r\n    const idleExpiry = localStorage.getItem(this.IDLE_EXPIRY_KEY);\r\n    if (\r\n      idleExpiry &&\r\n      parseInt(idleExpiry, 10) + this.idle.getTimeout() * 1000 < Date.now()\r\n    ) {\r\n      this.reset();\r\n      await Promise.resolve(this.onTimeout && this.onTimeout());\r\n    }\r\n  }\r\n\r\n  public async keepalivePost(): Promise<{\r\n    expiresAfterSeconds: number;\r\n    keepaliveResult: KeepaliveResult;\r\n  }> {\r\n    // currentAuthenticatedUser() refreshes the access token if required.\r\n    const cognitoUser: CognitoUser = await this.auth.currentAuthenticatedUser();\r\n\r\n    const keepaliveResult = await this.http\r\n      .post<KeepaliveResult>(`${this.config.authUrl}auth/keepalive/`, null, {\r\n        withCredentials: true, // /auth/keepalive/ will be extending the sessions cookie.\r\n        headers: {\r\n          Authorization: `Bearer ${cognitoUser\r\n            .getSignInUserSession()\r\n            .getAccessToken()\r\n            .getJwtToken()}`,\r\n        },\r\n      })\r\n      .toPromise();\r\n\r\n    return {\r\n      keepaliveResult,\r\n      expiresAfterSeconds:\r\n        this.idle.getIdle() +\r\n        this.idle.getTimeout() +\r\n        this.keepalive.interval(),\r\n    };\r\n  }\r\n\r\n  public async persistMasterKey(masterKey: Key): Promise<void> {\r\n    // The keepalive API call extends the server-side session, the session cookie expiry, refresh key cookie\r\n    // expiry, and returns the session expiry.\r\n    // NOTE Use time delta rather than absolute time, since client clock and server clock maybe\r\n    // out of sync. We can't use the serverTime() functionality because the cookie expiry still\r\n    // run on local clock.\r\n    const { expiresAfterSeconds } = await this.keepalivePost();\r\n\r\n    // Persist the derived passKey\r\n    await this.keyService.persistMasterKey(masterKey, expiresAfterSeconds);\r\n\r\n    console.log('setMasterKey() done');\r\n  }\r\n\r\n  private async onPing(): Promise<void> {\r\n    console.log(\r\n      `Keep alive triggered at time: ${Date.now()}. Interval set at: ${this.keepalive.interval()} seconds`\r\n    );\r\n\r\n    // Keepalive API will extend the session expiry.\r\n    const { expiresAfterSeconds } = await this.keepalivePost();\r\n\r\n    // Extend the expiry of the persisted key\r\n    await this.keyService.setMasterKeyExpiresAfterSeconds(expiresAfterSeconds);\r\n\r\n    await Promise.resolve(this.onKeepalive && this.onKeepalive());\r\n  }\r\n\r\n  public async start(): Promise<void> {\r\n    if (!this.initCalled) {\r\n      await this.init();\r\n    }\r\n\r\n    if (this.idle.isRunning()) {\r\n      return;\r\n    }\r\n\r\n    // Ping does not seem to happen right at the start. So we call it explicitly\r\n    await this.onPing();\r\n\r\n    this.idle.watch();\r\n  }\r\n\r\n  public stop(): void {\r\n    this.idle.stop();\r\n    this.reset();\r\n  }\r\n\r\n  private reset() {\r\n    localStorage.removeItem(this.IDLE_EXPIRY_KEY);\r\n    localStorage.removeItem(this.IDLING_KEY);\r\n  }\r\n}\r\n"]}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export var Config;
|
|
2
|
+
(function (Config) {
|
|
3
|
+
Config[Config["TIMEOUT"] = 0.01] = "TIMEOUT";
|
|
4
|
+
Config[Config["IDLE"] = 1200] = "IDLE";
|
|
5
|
+
Config[Config["KEEP_ALIVE_INTERVAL"] = 60] = "KEEP_ALIVE_INTERVAL";
|
|
6
|
+
})(Config || (Config = {}));
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWRsZS50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiJDOi9Qcm9qZWN0cy9uZXdyZXBvL2tjLWNsaWVudC9wcm9qZWN0cy9jb3JlL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9hdXRoL2lkbGUudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVksTUFJWDtBQUpELFdBQVksTUFBTTtJQUNoQiw0Q0FBYyxDQUFBO0lBQ2Qsc0NBQWMsQ0FBQTtJQUNkLGtFQUE0QixDQUFBO0FBQzlCLENBQUMsRUFKVyxNQUFNLEtBQU4sTUFBTSxRQUlqQiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIENvbmZpZyB7XHJcbiAgVElNRU9VVCA9IDAuMDEsIC8vIHNlY29uZHMsIG1pbiB2YWx1ZSAwLjAxLCBhZnRlciBzdGF0ZSBpcyBpZGxlLCB3YWl0IGZvciBUSU1FT1VUIHNlY29uZHMgYmVmb3JlIHRha2luZyBhY3Rpb25cclxuICBJRExFID0gNjAgKiAyMCwgLy8gc2Vjb25kcywgcGVyaW9kIG9mIGluYWN0aXZpdHkgdG8gY29uc2lkZXIgc3RhdGUgYXMgaWRsZVxyXG4gIEtFRVBfQUxJVkVfSU5URVJWQUwgPSA2MCAqIDEsIC8vIHNlY29uZHMsIHRyaWdnZXJlZCBvbiBhIHJlZ3VsYXIgYmFzaXMgd2hpbGUgYWN0aXZlIChpLmUuIHdoaWxlIG5vdCBpZGxpbmcpXHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgS2VlcGFsaXZlUmVzdWx0IHtcclxuICBzZXNzaW9uOiB7XHJcbiAgICBleHBpcmVzX2FmdGVyX3NlY29uZHM6IG51bWJlcjtcclxuICB9O1xyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,355 @@
|
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
2
|
+
import { LrApolloService } from '../api/lr-apollo.service';
|
|
3
|
+
import { HttpClient } from '@angular/common/http';
|
|
4
|
+
import { Inject, Injectable } from '@angular/core';
|
|
5
|
+
import { AuthClass } from '@aws-amplify/auth/lib-esm/Auth';
|
|
6
|
+
import gql from 'graphql-tag';
|
|
7
|
+
import { EncryptionService } from '../cryptography/encryption.service';
|
|
8
|
+
import { KeyGraphService } from '../cryptography/key-graph.service';
|
|
9
|
+
import { KeyService } from '../cryptography/key.service';
|
|
10
|
+
import { LR_CONFIG } from '../life-ready.config';
|
|
11
|
+
import { LrException, LrBadLogicException, } from '../_common/exceptions';
|
|
12
|
+
import { LifeReadyAuthService } from './life-ready-auth.service';
|
|
13
|
+
import { PasswordService } from './password.service';
|
|
14
|
+
import { Slip39Helper } from 'slip39';
|
|
15
|
+
import { KeyFactoryService as KFS } from '../cryptography/key-factory.service';
|
|
16
|
+
import * as i0 from "@angular/core";
|
|
17
|
+
import * as i1 from "../life-ready.config";
|
|
18
|
+
import * as i2 from "@angular/common/http";
|
|
19
|
+
import * as i3 from "../api/lr-apollo.service";
|
|
20
|
+
import * as i4 from "@aws-amplify/auth/lib-esm/Auth";
|
|
21
|
+
import * as i5 from "./life-ready-auth.service";
|
|
22
|
+
import * as i6 from "../cryptography/key-factory.service";
|
|
23
|
+
import * as i7 from "../cryptography/key.service";
|
|
24
|
+
import * as i8 from "../cryptography/encryption.service";
|
|
25
|
+
import * as i9 from "../cryptography/key-graph.service";
|
|
26
|
+
import * as i10 from "./password.service";
|
|
27
|
+
export const CreateLbopQuery = gql `
|
|
28
|
+
mutation CreateLbop($input: CreateLbopInput!) {
|
|
29
|
+
createLbop(input: $input) {
|
|
30
|
+
lbop {
|
|
31
|
+
id
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
`;
|
|
36
|
+
export const DeleteLbopQuery = gql `
|
|
37
|
+
mutation DeleteLbop($input: DeleteLbopInput!) {
|
|
38
|
+
deleteLbop(input: $input) {
|
|
39
|
+
id
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
`;
|
|
43
|
+
export const UpdateLbopQuery = gql `
|
|
44
|
+
mutation UpdateLbop($input: UpdateLbopInput!) {
|
|
45
|
+
updateLbop(input: $input) {
|
|
46
|
+
lbop {
|
|
47
|
+
id
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
`;
|
|
52
|
+
export const LbopQuery = gql `
|
|
53
|
+
query Lbop($id: LrRelayIdInput!) {
|
|
54
|
+
lbop(id: $id) {
|
|
55
|
+
id
|
|
56
|
+
cipherMeta
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
`;
|
|
60
|
+
export const LbopsQuery = gql `
|
|
61
|
+
query Lbops {
|
|
62
|
+
lbops {
|
|
63
|
+
edges {
|
|
64
|
+
node {
|
|
65
|
+
id
|
|
66
|
+
cipherMeta
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
`;
|
|
72
|
+
export class LbopService {
|
|
73
|
+
constructor(config, http, lrApollo, auth, authService, keyFactory, keyService, encryptionService, keyGraph, passwordService) {
|
|
74
|
+
this.config = config;
|
|
75
|
+
this.http = http;
|
|
76
|
+
this.lrApollo = lrApollo;
|
|
77
|
+
this.auth = auth;
|
|
78
|
+
this.authService = authService;
|
|
79
|
+
this.keyFactory = keyFactory;
|
|
80
|
+
this.keyService = keyService;
|
|
81
|
+
this.encryptionService = encryptionService;
|
|
82
|
+
this.keyGraph = keyGraph;
|
|
83
|
+
this.passwordService = passwordService;
|
|
84
|
+
this.CLIENT_NONCE_LENGTH = 32;
|
|
85
|
+
// There are 1024 words (10 bits), so 25 words should give ~256 bits of entropy.
|
|
86
|
+
this.LBOP_WORDS = 25;
|
|
87
|
+
}
|
|
88
|
+
getPartial(lbopString) {
|
|
89
|
+
return lbopString.split(' ')[0];
|
|
90
|
+
}
|
|
91
|
+
remove(id) {
|
|
92
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
93
|
+
const res = yield this.lrApollo.mutate({
|
|
94
|
+
mutation: DeleteLbopQuery,
|
|
95
|
+
variables: {
|
|
96
|
+
input: {
|
|
97
|
+
id,
|
|
98
|
+
},
|
|
99
|
+
},
|
|
100
|
+
});
|
|
101
|
+
return res.deleteLbop.id;
|
|
102
|
+
});
|
|
103
|
+
}
|
|
104
|
+
update({ id, name }) {
|
|
105
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
106
|
+
const lbop = yield this.get(id);
|
|
107
|
+
lbop.name = name;
|
|
108
|
+
const masterKey = yield this.keyService.getCurrentMasterKey();
|
|
109
|
+
const cipherMeta = yield this.encryptionService.encrypt(masterKey.jwk, lbop);
|
|
110
|
+
const res = yield this.lrApollo.mutate({
|
|
111
|
+
mutation: UpdateLbopQuery,
|
|
112
|
+
variables: {
|
|
113
|
+
input: {
|
|
114
|
+
id,
|
|
115
|
+
cipherMeta: JSON.stringify(cipherMeta),
|
|
116
|
+
},
|
|
117
|
+
},
|
|
118
|
+
});
|
|
119
|
+
return res.updateLbop;
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
get(id) {
|
|
123
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
124
|
+
const res = yield this.lrApollo.query({
|
|
125
|
+
query: LbopQuery,
|
|
126
|
+
variables: {
|
|
127
|
+
id,
|
|
128
|
+
},
|
|
129
|
+
});
|
|
130
|
+
const masterKey = yield this.keyService.getCurrentMasterKey();
|
|
131
|
+
const plainCipherMeta = yield this.encryptionService.decrypt(masterKey.jwk, JSON.parse(res.lbop.cipherMeta));
|
|
132
|
+
return Object.assign({ id: res.id }, plainCipherMeta);
|
|
133
|
+
});
|
|
134
|
+
}
|
|
135
|
+
list() {
|
|
136
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
137
|
+
const res = yield this.lrApollo.query({
|
|
138
|
+
query: LbopsQuery,
|
|
139
|
+
});
|
|
140
|
+
const masterKey = yield this.keyService.getCurrentMasterKey();
|
|
141
|
+
return Promise.all(res.lbops.edges.map((edge) => __awaiter(this, void 0, void 0, function* () {
|
|
142
|
+
const plainCipherMeta = yield this.encryptionService.decrypt(masterKey.jwk, JSON.parse(edge.node.cipherMeta));
|
|
143
|
+
return Object.assign({ id: edge.node.id }, plainCipherMeta);
|
|
144
|
+
})));
|
|
145
|
+
});
|
|
146
|
+
}
|
|
147
|
+
create({ name }) {
|
|
148
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
149
|
+
if (Slip39Helper.WORD_LIST.length !== 1024) {
|
|
150
|
+
throw new LrBadLogicException('Slip39Helper.WORD_LIST.length != 1024');
|
|
151
|
+
}
|
|
152
|
+
// Get existing to make sure there are not duplicate first words
|
|
153
|
+
const lbops = yield this.list();
|
|
154
|
+
// Generate new one
|
|
155
|
+
let lbopString;
|
|
156
|
+
while (true) {
|
|
157
|
+
lbopString = this.keyFactory
|
|
158
|
+
.randomChoices(Slip39Helper.WORD_LIST, this.LBOP_WORDS)
|
|
159
|
+
.join(' ');
|
|
160
|
+
const partial = this.getPartial(lbopString);
|
|
161
|
+
if (!lbops.some((lbop) => lbop.partial === partial)) {
|
|
162
|
+
break;
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
const lbopKeyParams = yield this.keyFactory.createLbopKeyParams();
|
|
166
|
+
const lbopKey = (yield this.keyFactory.deriveLbopKey(Object.assign({ password: lbopString }, lbopKeyParams))).jwk;
|
|
167
|
+
const lbopKeyVerifier = yield this.keyFactory.createSignKey();
|
|
168
|
+
const wrappedLbopKeyVerifier = yield this.encryptionService.encrypt(lbopKey, lbopKeyVerifier.toJSON(true));
|
|
169
|
+
// Re-encrypt master key with new key
|
|
170
|
+
const currentUser = yield this.authService.getUser();
|
|
171
|
+
const masterKey = yield this.keyGraph.getKey(currentUser.currentUserKey.masterKey.id);
|
|
172
|
+
const wrappedMasterKey = yield this.encryptionService.encrypt(lbopKey, masterKey.jwk.toJSON(true));
|
|
173
|
+
const meta = Object.assign(Object.assign({}, (name && { name })), { partial: this.getPartial(lbopString) });
|
|
174
|
+
const cipherMeta = yield this.encryptionService.encrypt(masterKey.jwk, meta);
|
|
175
|
+
const res = yield this.lrApollo.mutate({
|
|
176
|
+
mutation: CreateLbopQuery,
|
|
177
|
+
variables: {
|
|
178
|
+
input: {
|
|
179
|
+
cipherMeta: JSON.stringify(cipherMeta),
|
|
180
|
+
lbopKeyParams: JSON.stringify(lbopKeyParams),
|
|
181
|
+
lbopKeyVerifier: JSON.stringify(lbopKeyVerifier.toJSON(true)),
|
|
182
|
+
wrappedLbopKeyVerifier: JSON.stringify(wrappedLbopKeyVerifier),
|
|
183
|
+
masterKeyId: currentUser.currentUserKey.masterKey.id,
|
|
184
|
+
wrappedMasterKey: JSON.stringify(wrappedMasterKey),
|
|
185
|
+
},
|
|
186
|
+
},
|
|
187
|
+
});
|
|
188
|
+
return Object.assign(Object.assign({}, res.createLbop.lbop), { lbopString });
|
|
189
|
+
});
|
|
190
|
+
}
|
|
191
|
+
// --------------------------------------------------------------------------------------------------------------------
|
|
192
|
+
// --------------------------------------------------------------------------------------------------------------------
|
|
193
|
+
// Flow below are for password reset via LBOP
|
|
194
|
+
//
|
|
195
|
+
// --Potential Failure Point xxx--
|
|
196
|
+
//
|
|
197
|
+
// Look for the above and you can test by interrupting at these points.
|
|
198
|
+
//
|
|
199
|
+
// The LBOP reset process can be restarted at any point before the call to "set-password/". Once "set-password/" has been
|
|
200
|
+
// called, we assume the client has a short period of time to change the Idp password to the one they've chosen. The "set-password/"
|
|
201
|
+
// will set the Idp password to a temporary random password. The user can no longer login using their current password. If the Idp
|
|
202
|
+
// password change process does not complete or takes longer than the lockout period, the account will not be accessible and a new
|
|
203
|
+
// LBOP password reset must be carried out.
|
|
204
|
+
// --------------------------------------------------------------------------------------------------------------------
|
|
205
|
+
// --------------------------------------------------------------------------------------------------------------------
|
|
206
|
+
verifyLbops(challengeResult, lbopString) {
|
|
207
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
208
|
+
const clientNonce = this.keyFactory.randomString(this.CLIENT_NONCE_LENGTH);
|
|
209
|
+
for (const lbop of challengeResult.lbops) {
|
|
210
|
+
const lbopKey = (yield this.keyFactory.deriveLbopKey(Object.assign({ password: lbopString }, lbop.lbopKeyParams))).jwk;
|
|
211
|
+
// If decoding successful then it's the correct lbop
|
|
212
|
+
try {
|
|
213
|
+
const lbopKeyVerifier = (yield this.encryptionService.decrypt(lbopKey, lbop.wrappedLbopKeyVerifier));
|
|
214
|
+
// Force a bad signature.
|
|
215
|
+
// const serverNonce = challengeResult.challenge.serverNonce + "1",
|
|
216
|
+
const serverNonce = challengeResult.challenge.serverNonce;
|
|
217
|
+
const signedChallenge = yield this.encryptionService.sign(lbopKeyVerifier, {
|
|
218
|
+
serverNonce,
|
|
219
|
+
clientNonce,
|
|
220
|
+
});
|
|
221
|
+
return {
|
|
222
|
+
lbop,
|
|
223
|
+
signedChallenge,
|
|
224
|
+
lbopKey,
|
|
225
|
+
};
|
|
226
|
+
}
|
|
227
|
+
catch (error) {
|
|
228
|
+
continue;
|
|
229
|
+
}
|
|
230
|
+
}
|
|
231
|
+
throw new LrException({
|
|
232
|
+
source: 'LBOP',
|
|
233
|
+
code: 'INVALID_PASSPHRASE',
|
|
234
|
+
message: 'Invalid passphrase.',
|
|
235
|
+
});
|
|
236
|
+
});
|
|
237
|
+
}
|
|
238
|
+
verifyContact(params) {
|
|
239
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
240
|
+
const ret = this.http
|
|
241
|
+
.post(`${this.config.authUrl}users/lbop-reset/verify-contact/`, params)
|
|
242
|
+
.toPromise();
|
|
243
|
+
// --Potential Failure Point 1 --
|
|
244
|
+
// The contact verifications are throttled. But otherwise harmless.
|
|
245
|
+
return ret;
|
|
246
|
+
});
|
|
247
|
+
}
|
|
248
|
+
confirmContact(params) {
|
|
249
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
250
|
+
return this.http
|
|
251
|
+
.post(`${this.config.authUrl}cove/respond/`, {
|
|
252
|
+
claim_id: params.claimId,
|
|
253
|
+
v_code: params.vCode,
|
|
254
|
+
})
|
|
255
|
+
.toPromise();
|
|
256
|
+
// --Potential Failure Point 2 --
|
|
257
|
+
// A verified claim for a contact does not prevent new ones from being generated. So it should be fine to just start again.
|
|
258
|
+
});
|
|
259
|
+
}
|
|
260
|
+
verify(params) {
|
|
261
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
262
|
+
const challengeResult = yield this.http
|
|
263
|
+
.post(`${this.config.authUrl}users/lbop-reset/get-challenge/`, {
|
|
264
|
+
claimId: params.claimId,
|
|
265
|
+
claimToken: params.claimToken,
|
|
266
|
+
})
|
|
267
|
+
.toPromise();
|
|
268
|
+
// --Potential Failure Point 3 --
|
|
269
|
+
// This does not lock anything. A second call to "get-challenge/" will create a new challenge amd invalidate the first one.
|
|
270
|
+
const { signedChallenge, lbop, lbopKey } = yield this.verifyLbops(challengeResult, params.lbop);
|
|
271
|
+
const res = yield this.http
|
|
272
|
+
.post(`${this.config.authUrl}users/lbop-reset/verify-challenge/`, {
|
|
273
|
+
lbopId: lbop.lbopId,
|
|
274
|
+
signedChallenge,
|
|
275
|
+
})
|
|
276
|
+
.toPromise();
|
|
277
|
+
// --Potential Failure Point 4 --
|
|
278
|
+
// This does not lock anything. So ok to restart.
|
|
279
|
+
return {
|
|
280
|
+
lbopId: lbop.lbopId,
|
|
281
|
+
verifiedToken: res.verifiedToken,
|
|
282
|
+
masterKeyId: res.masterKeyId,
|
|
283
|
+
masterKey: yield KFS.asKey(yield this.encryptionService.decrypt(lbopKey, res.wrappedMasterKey)),
|
|
284
|
+
};
|
|
285
|
+
});
|
|
286
|
+
}
|
|
287
|
+
setPassword(params) {
|
|
288
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
289
|
+
// Generate the new password derived keys
|
|
290
|
+
const passKeyBundle = yield this.passwordService.createPassKeyBundle(params.newPassword);
|
|
291
|
+
// Re-encrypt master key with new key
|
|
292
|
+
const newWrappedMasterKey = yield this.encryptionService.encrypt(passKeyBundle.passKey, params.masterKey.toJSON(true));
|
|
293
|
+
const result = yield this.http
|
|
294
|
+
.post(`${this.config.authUrl}users/lbop-reset/set-password/`, {
|
|
295
|
+
lbopId: params.lbopId,
|
|
296
|
+
verifiedToken: params.verifiedToken,
|
|
297
|
+
masterKeyId: params.masterKeyId,
|
|
298
|
+
newWrappedMasterKey,
|
|
299
|
+
newPassKey: {
|
|
300
|
+
passKeyParams: passKeyBundle.passKeyParams,
|
|
301
|
+
passIdpParams: passKeyBundle.passIdpParams,
|
|
302
|
+
passIdpVerifierPbk: passKeyBundle.passIdpVerifier.toJSON(),
|
|
303
|
+
wrappedPassIdpVerifierPrk: passKeyBundle.wrappedPassIdpVerifierPrk,
|
|
304
|
+
},
|
|
305
|
+
})
|
|
306
|
+
.toPromise();
|
|
307
|
+
// --Potential Failure Point 5 --
|
|
308
|
+
// A timed mutex is locked. The Idp password change must occur within a period of time.
|
|
309
|
+
// If interrupted here, the user can not login with their old password again. They must
|
|
310
|
+
// start the whole LBOP password reset process again.
|
|
311
|
+
// This call will go through the LR proxy which is OK since the LR server knows
|
|
312
|
+
// the temporary password anyway.
|
|
313
|
+
let user = yield this.auth.signIn(result.username, result.idpPassword, {
|
|
314
|
+
noProxy: 'true',
|
|
315
|
+
});
|
|
316
|
+
if (user.challengeName !== 'NEW_PASSWORD_REQUIRED') {
|
|
317
|
+
throw new LrException({
|
|
318
|
+
message: 'Internal error. Expecting Cognito to have done a password reset.',
|
|
319
|
+
});
|
|
320
|
+
}
|
|
321
|
+
// --Potential Failure Point 6 --
|
|
322
|
+
// Must restart the LBOP password reset process again.
|
|
323
|
+
// Set new password on Idp
|
|
324
|
+
user = yield this.auth.completeNewPassword(user, this.passwordService.getPassIdpString(passKeyBundle.passIdp), {});
|
|
325
|
+
// --Potential Failure Point 7 --
|
|
326
|
+
// Must restart the LBOP password reset process again.
|
|
327
|
+
yield this.auth.signOut();
|
|
328
|
+
return yield this.http
|
|
329
|
+
.post(`${this.config.authUrl}users/lbop-reset/complete/`, {
|
|
330
|
+
lbopId: params.lbopId,
|
|
331
|
+
setPasswordToken: result.setPasswordToken,
|
|
332
|
+
})
|
|
333
|
+
.toPromise();
|
|
334
|
+
});
|
|
335
|
+
}
|
|
336
|
+
}
|
|
337
|
+
LbopService.ɵprov = i0.ɵɵdefineInjectable({ factory: function LbopService_Factory() { return new LbopService(i0.ɵɵinject(i1.LR_CONFIG), i0.ɵɵinject(i2.HttpClient), i0.ɵɵinject(i3.LrApolloService), i0.ɵɵinject(i4.AuthClass), i0.ɵɵinject(i5.LifeReadyAuthService), i0.ɵɵinject(i6.KeyFactoryService), i0.ɵɵinject(i7.KeyService), i0.ɵɵinject(i8.EncryptionService), i0.ɵɵinject(i9.KeyGraphService), i0.ɵɵinject(i10.PasswordService)); }, token: LbopService, providedIn: "root" });
|
|
338
|
+
LbopService.decorators = [
|
|
339
|
+
{ type: Injectable, args: [{
|
|
340
|
+
providedIn: 'root',
|
|
341
|
+
},] }
|
|
342
|
+
];
|
|
343
|
+
LbopService.ctorParameters = () => [
|
|
344
|
+
{ type: undefined, decorators: [{ type: Inject, args: [LR_CONFIG,] }] },
|
|
345
|
+
{ type: HttpClient },
|
|
346
|
+
{ type: LrApolloService },
|
|
347
|
+
{ type: AuthClass },
|
|
348
|
+
{ type: LifeReadyAuthService },
|
|
349
|
+
{ type: KFS },
|
|
350
|
+
{ type: KeyService },
|
|
351
|
+
{ type: EncryptionService },
|
|
352
|
+
{ type: KeyGraphService },
|
|
353
|
+
{ type: PasswordService }
|
|
354
|
+
];
|
|
355
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lbop.service.js","sourceRoot":"C:/Projects/newrepo/kc-client/projects/core/src/","sources":["lib/auth/lbop.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { LrApolloService } from '../api/lr-apollo.service';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { Inject, Injectable } from '@angular/core';\r\nimport { AuthClass } from '@aws-amplify/auth/lib-esm/Auth';\r\nimport gql from 'graphql-tag';\r\nimport { JWK } from 'node-jose';\r\nimport { EncryptionService } from '../cryptography/encryption.service';\r\nimport { KeyGraphService } from '../cryptography/key-graph.service';\r\nimport { KeyService } from '../cryptography/key.service';\r\nimport { LifeReadyConfig, LR_CONFIG } from '../life-ready.config';\r\nimport {\r\n  LrException,\r\n  LrErrorCode,\r\n  LrBadLogicException,\r\n} from '../_common/exceptions';\r\nimport { LifeReadyAuthService } from './life-ready-auth.service';\r\nimport { PasswordService } from './password.service';\r\nimport { Slip39Helper } from 'slip39';\r\nimport { KeyFactoryService as KFS } from '../cryptography/key-factory.service';\r\n\r\ninterface SetPasswordApiResult {\r\n  username: string;\r\n  idpPassword: string;\r\n  setPasswordToken: string;\r\n}\r\n\r\nexport interface SetPasswordParams {\r\n  lbopId: string;\r\n  newPassword: string;\r\n  verifiedToken: string;\r\n  masterKeyId: string;\r\n  masterKey: JWK.Key;\r\n}\r\n\r\nexport interface VerifyContactParams {\r\n  email?: string;\r\n  phone?: string;\r\n}\r\n\r\nexport interface VerifyContactResult {\r\n  // The claim_id identifies the Email/SMS confirmation\r\n  claimId: string;\r\n}\r\n\r\nexport interface ConfirmContactParams {\r\n  claimId: string;\r\n  vCode: string;\r\n}\r\n\r\nexport interface ConfirmContactResult {\r\n  // The token to prove the client had the correct confirmation code.\r\n  token: string;\r\n}\r\n\r\nexport interface VerifyParams {\r\n  claimId: string;\r\n  claimToken: string;\r\n  lbop: string;\r\n}\r\n\r\nexport interface VerifyResult {\r\n  // userId: string;\r\n  lbopId: string;\r\n  verifiedToken: string;\r\n  masterKeyId: string;\r\n  masterKey: JWK.Key;\r\n}\r\n\r\nexport interface ChallengeResult {\r\n  challenge: any;\r\n  lbops: any;\r\n  // userId: string;\r\n}\r\n\r\nexport interface Lbop {\r\n  id: string;\r\n  partial?: string;\r\n  name?: string;\r\n  lbopString?: string;\r\n}\r\n\r\nexport interface CreateLbopParams {\r\n  name?: string;\r\n}\r\n\r\ninterface CreateLbopQuery {\r\n  createLbop: {\r\n    lbop: Lbop;\r\n  };\r\n}\r\n\r\nexport const CreateLbopQuery = gql`\r\n  mutation CreateLbop($input: CreateLbopInput!) {\r\n    createLbop(input: $input) {\r\n      lbop {\r\n        id\r\n      }\r\n    }\r\n  }\r\n`;\r\n\r\ninterface DeleteLbopQuery {\r\n  deleteLbop: Lbop;\r\n}\r\n\r\nexport const DeleteLbopQuery = gql`\r\n  mutation DeleteLbop($input: DeleteLbopInput!) {\r\n    deleteLbop(input: $input) {\r\n      id\r\n    }\r\n  }\r\n`;\r\n\r\nexport interface UpdateLbopParams {\r\n  id: string;\r\n  name: string;\r\n}\r\n\r\ninterface UpdateLbopQuery {\r\n  updateLbop: Lbop;\r\n}\r\n\r\nexport const UpdateLbopQuery = gql`\r\n  mutation UpdateLbop($input: UpdateLbopInput!) {\r\n    updateLbop(input: $input) {\r\n      lbop {\r\n        id\r\n      }\r\n    }\r\n  }\r\n`;\r\n\r\nexport const LbopQuery = gql`\r\n  query Lbop($id: LrRelayIdInput!) {\r\n    lbop(id: $id) {\r\n      id\r\n      cipherMeta\r\n    }\r\n  }\r\n`;\r\n\r\ninterface LbopsQuery {\r\n  lbops: any;\r\n}\r\n\r\nexport const LbopsQuery = gql`\r\n  query Lbops {\r\n    lbops {\r\n      edges {\r\n        node {\r\n          id\r\n          cipherMeta\r\n        }\r\n      }\r\n    }\r\n  }\r\n`;\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class LbopService {\r\n  private readonly CLIENT_NONCE_LENGTH = 32;\r\n  // There are 1024 words (10 bits), so 25 words should give ~256 bits of entropy.\r\n  private readonly LBOP_WORDS = 25;\r\n\r\n  constructor(\r\n    @Inject(LR_CONFIG) private config: LifeReadyConfig,\r\n    private http: HttpClient,\r\n    private lrApollo: LrApolloService,\r\n    private auth: AuthClass,\r\n    private authService: LifeReadyAuthService,\r\n    private keyFactory: KFS,\r\n    private keyService: KeyService,\r\n    private encryptionService: EncryptionService,\r\n    private keyGraph: KeyGraphService,\r\n    private passwordService: PasswordService\r\n  ) {}\r\n\r\n  private getPartial(lbopString: string): string {\r\n    return lbopString.split(' ')[0];\r\n  }\r\n\r\n  public async remove(id: string): Promise<string> {\r\n    const res = await this.lrApollo.mutate<any>({\r\n      mutation: DeleteLbopQuery,\r\n      variables: {\r\n        input: {\r\n          id,\r\n        },\r\n      },\r\n    });\r\n\r\n    return res.deleteLbop.id;\r\n  }\r\n\r\n  public async update({ id, name }: UpdateLbopParams): Promise<Lbop> {\r\n    const lbop = await this.get(id);\r\n    lbop.name = name;\r\n\r\n    const masterKey = await this.keyService.getCurrentMasterKey();\r\n    const cipherMeta = await this.encryptionService.encrypt(\r\n      masterKey.jwk,\r\n      lbop\r\n    );\r\n\r\n    const res = await this.lrApollo.mutate<UpdateLbopQuery>({\r\n      mutation: UpdateLbopQuery,\r\n      variables: {\r\n        input: {\r\n          id,\r\n          cipherMeta: JSON.stringify(cipherMeta),\r\n        },\r\n      },\r\n    });\r\n\r\n    return res.updateLbop;\r\n  }\r\n\r\n  public async get(id: string): Promise<Lbop> {\r\n    const res = await this.lrApollo.query<any>({\r\n      query: LbopQuery,\r\n      variables: {\r\n        id,\r\n      },\r\n    });\r\n\r\n    const masterKey = await this.keyService.getCurrentMasterKey();\r\n\r\n    const plainCipherMeta = await this.encryptionService.decrypt(\r\n      masterKey.jwk,\r\n      JSON.parse(res.lbop.cipherMeta)\r\n    );\r\n\r\n    return {\r\n      id: res.id,\r\n      ...plainCipherMeta,\r\n    };\r\n  }\r\n\r\n  public async list(): Promise<Lbop[]> {\r\n    const res = await this.lrApollo.query<LbopsQuery>({\r\n      query: LbopsQuery,\r\n    });\r\n\r\n    const masterKey = await this.keyService.getCurrentMasterKey();\r\n\r\n    return Promise.all(\r\n      res.lbops.edges.map(async (edge) => {\r\n        const plainCipherMeta = await this.encryptionService.decrypt(\r\n          masterKey.jwk,\r\n          JSON.parse(edge.node.cipherMeta)\r\n        );\r\n        return {\r\n          id: edge.node.id,\r\n          ...plainCipherMeta,\r\n        };\r\n      })\r\n    );\r\n  }\r\n\r\n  public async create({ name }: CreateLbopParams): Promise<Lbop> {\r\n    if (Slip39Helper.WORD_LIST.length !== 1024) {\r\n      throw new LrBadLogicException('Slip39Helper.WORD_LIST.length != 1024');\r\n    }\r\n\r\n    // Get existing to make sure there are not duplicate first words\r\n    const lbops = await this.list();\r\n\r\n    // Generate new one\r\n    let lbopString;\r\n    while (true) {\r\n      lbopString = this.keyFactory\r\n        .randomChoices(Slip39Helper.WORD_LIST, this.LBOP_WORDS)\r\n        .join(' ');\r\n      const partial = this.getPartial(lbopString);\r\n\r\n      if (!lbops.some((lbop) => lbop.partial === partial)) {\r\n        break;\r\n      }\r\n    }\r\n\r\n    const lbopKeyParams = await this.keyFactory.createLbopKeyParams();\r\n    const lbopKey = (\r\n      await this.keyFactory.deriveLbopKey({\r\n        password: lbopString,\r\n        ...lbopKeyParams,\r\n      })\r\n    ).jwk;\r\n\r\n    const lbopKeyVerifier = await this.keyFactory.createSignKey();\r\n    const wrappedLbopKeyVerifier = await this.encryptionService.encrypt(\r\n      lbopKey,\r\n      lbopKeyVerifier.toJSON(true)\r\n    );\r\n\r\n    // Re-encrypt master key with new key\r\n    const currentUser = await this.authService.getUser();\r\n    const masterKey = await this.keyGraph.getKey(\r\n      currentUser.currentUserKey.masterKey.id\r\n    );\r\n    const wrappedMasterKey = await this.encryptionService.encrypt(\r\n      lbopKey,\r\n      masterKey.jwk.toJSON(true)\r\n    );\r\n\r\n    const meta = {\r\n      ...(name && { name }),\r\n      partial: this.getPartial(lbopString),\r\n    };\r\n    const cipherMeta = await this.encryptionService.encrypt(\r\n      masterKey.jwk,\r\n      meta\r\n    );\r\n\r\n    const res = await this.lrApollo.mutate<CreateLbopQuery>({\r\n      mutation: CreateLbopQuery,\r\n      variables: {\r\n        input: {\r\n          cipherMeta: JSON.stringify(cipherMeta),\r\n          lbopKeyParams: JSON.stringify(lbopKeyParams),\r\n          lbopKeyVerifier: JSON.stringify(lbopKeyVerifier.toJSON(true)),\r\n          wrappedLbopKeyVerifier: JSON.stringify(wrappedLbopKeyVerifier),\r\n          masterKeyId: currentUser.currentUserKey.masterKey.id,\r\n          wrappedMasterKey: JSON.stringify(wrappedMasterKey),\r\n        },\r\n      },\r\n    });\r\n\r\n    return {\r\n      ...res.createLbop.lbop,\r\n      lbopString,\r\n    };\r\n  }\r\n\r\n  // --------------------------------------------------------------------------------------------------------------------\r\n  // --------------------------------------------------------------------------------------------------------------------\r\n  // Flow below are for password reset via LBOP\r\n  //\r\n  // --Potential Failure Point xxx--\r\n  //\r\n  // Look for the above and you can test by interrupting at these points.\r\n  //\r\n  // The LBOP reset process can be restarted at any point before the call to \"set-password/\". Once \"set-password/\" has been\r\n  // called, we assume the client has a short period of time to change the Idp password to the one they've chosen. The \"set-password/\"\r\n  // will set the Idp password to a temporary random password. The user can no longer login using their current password. If the Idp\r\n  // password change process does not complete or takes longer than the lockout period, the account will not be accessible and a new\r\n  // LBOP password reset must be carried out.\r\n  // --------------------------------------------------------------------------------------------------------------------\r\n  // --------------------------------------------------------------------------------------------------------------------\r\n  private async verifyLbops(\r\n    challengeResult: ChallengeResult,\r\n    lbopString: string\r\n  ): Promise<{ lbop: any; signedChallenge: any; lbopKey: JWK.Key }> {\r\n    const clientNonce = this.keyFactory.randomString(this.CLIENT_NONCE_LENGTH);\r\n\r\n    for (const lbop of challengeResult.lbops) {\r\n      const lbopKey = (\r\n        await this.keyFactory.deriveLbopKey({\r\n          password: lbopString,\r\n          ...lbop.lbopKeyParams,\r\n        })\r\n      ).jwk;\r\n\r\n      // If decoding successful then it's the correct lbop\r\n      try {\r\n        const lbopKeyVerifier = (await this.encryptionService.decrypt(\r\n          lbopKey,\r\n          lbop.wrappedLbopKeyVerifier\r\n        )) as any;\r\n\r\n        // Force a bad signature.\r\n        // const serverNonce = challengeResult.challenge.serverNonce + \"1\",\r\n\r\n        const serverNonce = challengeResult.challenge.serverNonce;\r\n\r\n        const signedChallenge = await this.encryptionService.sign(\r\n          lbopKeyVerifier,\r\n          {\r\n            serverNonce,\r\n            clientNonce,\r\n          }\r\n        );\r\n\r\n        return {\r\n          lbop,\r\n          signedChallenge,\r\n          lbopKey,\r\n        };\r\n      } catch (error) {\r\n        continue;\r\n      }\r\n    }\r\n    throw new LrException({\r\n      source: 'LBOP',\r\n      code: 'INVALID_PASSPHRASE',\r\n      message: 'Invalid passphrase.',\r\n    });\r\n  }\r\n\r\n  public async verifyContact(\r\n    params: VerifyContactParams\r\n  ): Promise<VerifyContactResult> {\r\n    const ret = this.http\r\n      .post<VerifyContactResult>(\r\n        `${this.config.authUrl}users/lbop-reset/verify-contact/`,\r\n        params\r\n      )\r\n      .toPromise();\r\n\r\n    // --Potential Failure Point 1 --\r\n    // The contact verifications are throttled. But otherwise harmless.\r\n\r\n    return ret;\r\n  }\r\n\r\n  public async confirmContact(\r\n    params: ConfirmContactParams\r\n  ): Promise<ConfirmContactResult> {\r\n    return this.http\r\n      .post<ConfirmContactResult>(`${this.config.authUrl}cove/respond/`, {\r\n        claim_id: params.claimId,\r\n        v_code: params.vCode,\r\n      })\r\n      .toPromise();\r\n\r\n    // --Potential Failure Point 2 --\r\n    // A verified claim for a contact does not prevent new ones from being generated. So it should be fine to just start again.\r\n  }\r\n\r\n  public async verify(params: VerifyParams): Promise<VerifyResult> {\r\n    const challengeResult = await this.http\r\n      .post<ChallengeResult>(\r\n        `${this.config.authUrl}users/lbop-reset/get-challenge/`,\r\n        {\r\n          claimId: params.claimId,\r\n          claimToken: params.claimToken,\r\n        }\r\n      )\r\n      .toPromise();\r\n\r\n    // --Potential Failure Point 3 --\r\n    // This does not lock anything. A second call to \"get-challenge/\" will create a new challenge amd invalidate the first one.\r\n    const { signedChallenge, lbop, lbopKey } = await this.verifyLbops(\r\n      challengeResult,\r\n      params.lbop\r\n    );\r\n\r\n    const res = await this.http\r\n      .post<any>(`${this.config.authUrl}users/lbop-reset/verify-challenge/`, {\r\n        lbopId: lbop.lbopId,\r\n        signedChallenge,\r\n      })\r\n      .toPromise();\r\n\r\n    // --Potential Failure Point 4 --\r\n    // This does not lock anything. So ok to restart.\r\n\r\n    return {\r\n      lbopId: lbop.lbopId,\r\n      verifiedToken: res.verifiedToken,\r\n      masterKeyId: res.masterKeyId,\r\n      masterKey: await KFS.asKey(\r\n        await this.encryptionService.decrypt(lbopKey, res.wrappedMasterKey)\r\n      ),\r\n    };\r\n  }\r\n\r\n  public async setPassword(params: SetPasswordParams): Promise<any> {\r\n    // Generate the new password derived keys\r\n    const passKeyBundle = await this.passwordService.createPassKeyBundle(\r\n      params.newPassword\r\n    );\r\n\r\n    // Re-encrypt master key with new key\r\n    const newWrappedMasterKey = await this.encryptionService.encrypt(\r\n      passKeyBundle.passKey,\r\n      params.masterKey.toJSON(true)\r\n    );\r\n\r\n    const result = await this.http\r\n      .post<SetPasswordApiResult>(\r\n        `${this.config.authUrl}users/lbop-reset/set-password/`,\r\n        {\r\n          lbopId: params.lbopId,\r\n          verifiedToken: params.verifiedToken,\r\n          masterKeyId: params.masterKeyId,\r\n          newWrappedMasterKey,\r\n          newPassKey: {\r\n            passKeyParams: passKeyBundle.passKeyParams,\r\n            passIdpParams: passKeyBundle.passIdpParams,\r\n            passIdpVerifierPbk: passKeyBundle.passIdpVerifier.toJSON(),\r\n            wrappedPassIdpVerifierPrk: passKeyBundle.wrappedPassIdpVerifierPrk,\r\n          },\r\n        }\r\n      )\r\n      .toPromise();\r\n\r\n    // --Potential Failure Point 5 --\r\n    // A timed mutex is locked. The Idp password change must occur within a period of time.\r\n    // If interrupted here, the user can not login with their old password again. They must\r\n    // start the whole LBOP password reset process again.\r\n\r\n    // This call will go through the LR proxy which is OK since the LR server knows\r\n    // the temporary password anyway.\r\n    let user = await this.auth.signIn(result.username, result.idpPassword, {\r\n      noProxy: 'true',\r\n    });\r\n\r\n    if (user.challengeName !== 'NEW_PASSWORD_REQUIRED') {\r\n      throw new LrException({\r\n        message:\r\n          'Internal error. Expecting Cognito to have done a password reset.',\r\n      });\r\n    }\r\n\r\n    // --Potential Failure Point 6 --\r\n    // Must restart the LBOP password reset process again.\r\n\r\n    // Set new password on Idp\r\n    user = await this.auth.completeNewPassword(\r\n      user,\r\n      this.passwordService.getPassIdpString(passKeyBundle.passIdp),\r\n      {}\r\n    );\r\n\r\n    // --Potential Failure Point 7 --\r\n    // Must restart the LBOP password reset process again.\r\n\r\n    await this.auth.signOut();\r\n\r\n    return await this.http\r\n      .post<any>(`${this.config.authUrl}users/lbop-reset/complete/`, {\r\n        lbopId: params.lbopId,\r\n        setPasswordToken: result.setPasswordToken,\r\n      })\r\n      .toPromise();\r\n  }\r\n}\r\n"]}
|