@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,300 @@
|
|
|
1
|
+
import { __awaiter, __rest } from "tslib";
|
|
2
|
+
import { Injectable } from '@angular/core';
|
|
3
|
+
import { LrApolloService } from '../../api/lr-apollo.service';
|
|
4
|
+
import { EncryptionService } from '../../cryptography/encryption.service';
|
|
5
|
+
import { KeyFactoryService } from '../../cryptography/key-factory.service';
|
|
6
|
+
import { KeyGraphService } from '../../cryptography/key-graph.service';
|
|
7
|
+
import { KeyMetaService } from '../../cryptography/key-meta.service';
|
|
8
|
+
import * as slip from '../../cryptography/slip39.service';
|
|
9
|
+
import { TrustedPartyService } from '../../trusted-parties/trusted-party.service';
|
|
10
|
+
import { CreateScenarioApproverAssemblyMutation, DeleteScenarioApproverAssemblyMutation, GetScenarioApproverQuery, UpdateScenarioApproverAssemblyMutation, UpdateScenarioApproverMutation, } from './scenario-approval.gql';
|
|
11
|
+
import * as i0 from "@angular/core";
|
|
12
|
+
import * as i1 from "../../api/lr-apollo.service";
|
|
13
|
+
import * as i2 from "../../cryptography/key-factory.service";
|
|
14
|
+
import * as i3 from "../../cryptography/key-meta.service";
|
|
15
|
+
import * as i4 from "../../cryptography/key-graph.service";
|
|
16
|
+
import * as i5 from "../../cryptography/slip39.service";
|
|
17
|
+
import * as i6 from "../../cryptography/encryption.service";
|
|
18
|
+
import * as i7 from "../../trusted-parties/trusted-party.service";
|
|
19
|
+
export class ScenarioApproverService {
|
|
20
|
+
constructor(lrApollo, keyFactory, keyMetaService, keyGraph, slip39Service, encryptionService, trustedPartyService) {
|
|
21
|
+
this.lrApollo = lrApollo;
|
|
22
|
+
this.keyFactory = keyFactory;
|
|
23
|
+
this.keyMetaService = keyMetaService;
|
|
24
|
+
this.keyGraph = keyGraph;
|
|
25
|
+
this.slip39Service = slip39Service;
|
|
26
|
+
this.encryptionService = encryptionService;
|
|
27
|
+
this.trustedPartyService = trustedPartyService;
|
|
28
|
+
}
|
|
29
|
+
getApprover(approverId) {
|
|
30
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
31
|
+
const { scenarioApprover } = yield this.lrApollo.query({
|
|
32
|
+
query: GetScenarioApproverQuery,
|
|
33
|
+
variables: {
|
|
34
|
+
id: approverId,
|
|
35
|
+
},
|
|
36
|
+
});
|
|
37
|
+
return this.mapApprover(scenarioApprover);
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
mapApproverGroup(group) {
|
|
41
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
42
|
+
const { name } = yield this.keyGraph.decryptFromString(group.assemblyKey.id, group.subAssemblyCipherData);
|
|
43
|
+
return {
|
|
44
|
+
id: group.id,
|
|
45
|
+
keyId: group.assemblyKey.id,
|
|
46
|
+
name,
|
|
47
|
+
quorum: group.quorum,
|
|
48
|
+
singleReject: group.singleReject,
|
|
49
|
+
approvers: yield Promise.all(group.approvers.edges.map((x) => this.mapApprover(x.node))),
|
|
50
|
+
};
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
mapApprover(approver) {
|
|
54
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
55
|
+
const { message } = yield this.keyGraph.decryptFromString(approver.sharedKey.id, approver.sharedCipherData);
|
|
56
|
+
return {
|
|
57
|
+
id: approver.id,
|
|
58
|
+
keyId: approver.sharedKey.id,
|
|
59
|
+
trustedParty: yield this.trustedPartyService.mapTrustedParty(approver.tp),
|
|
60
|
+
message,
|
|
61
|
+
};
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
updateApprover(approver) {
|
|
65
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
66
|
+
const sharedCipherData = yield this.keyGraph.encryptToString(approver.keyId, approver.plainSharedCipherData);
|
|
67
|
+
yield this.lrApollo.mutate({
|
|
68
|
+
mutation: UpdateScenarioApproverMutation,
|
|
69
|
+
variables: {
|
|
70
|
+
input: {
|
|
71
|
+
approverId: approver.approverId,
|
|
72
|
+
sharedKeyId: approver.keyId,
|
|
73
|
+
sharedCipherData,
|
|
74
|
+
sharedCipherApprovalData: '',
|
|
75
|
+
},
|
|
76
|
+
},
|
|
77
|
+
});
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
createScenarioApproverAssembly(input) {
|
|
81
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
82
|
+
const assemblyKey = yield this.keyFactory.createKey();
|
|
83
|
+
const subjectKeyWrappedAssemblyKey = yield this.keyGraph.encryptToString(input.keyId, assemblyKey.toJSON(true));
|
|
84
|
+
const assemblyCipherData = input.plainAssemblyCipherData
|
|
85
|
+
? yield this.keyGraph.encryptToString(assemblyKey, input.plainAssemblyCipherData)
|
|
86
|
+
: '';
|
|
87
|
+
const { createScenarioApproverAssembly } = yield this.lrApollo.mutate({
|
|
88
|
+
mutation: CreateScenarioApproverAssemblyMutation,
|
|
89
|
+
variables: {
|
|
90
|
+
input: {
|
|
91
|
+
scenarioId: input.scenarioId,
|
|
92
|
+
singleReject: input.singleReject,
|
|
93
|
+
quorum: input.quorum,
|
|
94
|
+
subjectKeyId: input.keyId,
|
|
95
|
+
subjectKeyWrappedAssemblyKey,
|
|
96
|
+
assemblyCipherData,
|
|
97
|
+
createSubAssemblies: (yield this.mapApprovalGroups(input.approvalGroups, input.quorum, assemblyKey)).map((x) => {
|
|
98
|
+
const { updateApprovers, deleteApprovers } = x, subAssembly = __rest(x, ["updateApprovers", "deleteApprovers"]);
|
|
99
|
+
return subAssembly;
|
|
100
|
+
}),
|
|
101
|
+
updateReceivers: yield this.rewrapReceivers(assemblyKey, input.event, input.receivers),
|
|
102
|
+
},
|
|
103
|
+
},
|
|
104
|
+
});
|
|
105
|
+
return createScenarioApproverAssembly.scenario.approverAssembly.assemblyKey
|
|
106
|
+
.id;
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
updateScenarioApproverAssembly(input) {
|
|
110
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
111
|
+
const assemblyKey = yield this.keyGraph.getKey(input.assemblyKeyId);
|
|
112
|
+
const assemblyCipherData = input.plainAssemblyCipherData
|
|
113
|
+
? yield this.keyGraph.encryptToString(assemblyKey.jwk, input.plainAssemblyCipherData)
|
|
114
|
+
: '';
|
|
115
|
+
const approvalGroups = yield this.mapApprovalGroups(input.approvalGroups, input.quorum, assemblyKey.jwk);
|
|
116
|
+
yield this.lrApollo.mutate({
|
|
117
|
+
mutation: UpdateScenarioApproverAssemblyMutation,
|
|
118
|
+
variables: {
|
|
119
|
+
input: {
|
|
120
|
+
scenarioId: input.scenarioId,
|
|
121
|
+
singleReject: input.singleReject,
|
|
122
|
+
quorum: input.quorum,
|
|
123
|
+
assemblyKeyId: assemblyKey.id,
|
|
124
|
+
assemblyCipherData,
|
|
125
|
+
createSubAssemblies: approvalGroups
|
|
126
|
+
.filter((x) => !x.subAssemblyId)
|
|
127
|
+
.map((x) => {
|
|
128
|
+
const { updateApprovers, deleteApprovers } = x, subAssembly = __rest(x, ["updateApprovers", "deleteApprovers"]);
|
|
129
|
+
return subAssembly;
|
|
130
|
+
}),
|
|
131
|
+
updateSubAssemblies: approvalGroups.filter((x) => x.subAssemblyId),
|
|
132
|
+
deleteSubAssemblies: input.deletedGroupIds,
|
|
133
|
+
},
|
|
134
|
+
},
|
|
135
|
+
});
|
|
136
|
+
});
|
|
137
|
+
}
|
|
138
|
+
deleteScenarioApproverAssembly(scenarioId, event, receivers) {
|
|
139
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
140
|
+
yield this.lrApollo.mutate({
|
|
141
|
+
mutation: DeleteScenarioApproverAssemblyMutation,
|
|
142
|
+
variables: {
|
|
143
|
+
input: {
|
|
144
|
+
scenarioId,
|
|
145
|
+
updateReceivers: yield this.rewrapReceivers(null, event, receivers),
|
|
146
|
+
},
|
|
147
|
+
},
|
|
148
|
+
});
|
|
149
|
+
});
|
|
150
|
+
}
|
|
151
|
+
rewrapReceivers(assemblyKey, event, receivers) {
|
|
152
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
153
|
+
if (!receivers || !receivers.length) {
|
|
154
|
+
return [];
|
|
155
|
+
}
|
|
156
|
+
return yield Promise.all(receivers.map((receiver) => __awaiter(this, void 0, void 0, function* () {
|
|
157
|
+
const sharedKey = yield this.keyGraph.getKey(receiver.keyId);
|
|
158
|
+
const prepareReceiverItem = (item, itemKeyId) => __awaiter(this, void 0, void 0, function* () {
|
|
159
|
+
const itemKey = yield this.keyGraph.getKey(itemKeyId);
|
|
160
|
+
let wrappedItemKey = yield this.keyGraph.encryptToString(sharedKey.jwk, itemKey.jwk.toJSON(true));
|
|
161
|
+
if (assemblyKey) {
|
|
162
|
+
wrappedItemKey = yield this.keyGraph.encryptToString(assemblyKey, wrappedItemKey);
|
|
163
|
+
}
|
|
164
|
+
return {
|
|
165
|
+
accessRole: item.accessLevel,
|
|
166
|
+
sharedKeyId: sharedKey.id,
|
|
167
|
+
sharedCipherData: '',
|
|
168
|
+
wrappedItemKey,
|
|
169
|
+
};
|
|
170
|
+
});
|
|
171
|
+
// For each receiver-directory
|
|
172
|
+
const receiverDirectories = yield Promise.all([
|
|
173
|
+
...receiver.categories.map((x) => __awaiter(this, void 0, void 0, function* () {
|
|
174
|
+
return (Object.assign(Object.assign({}, (yield prepareReceiverItem(x, x.category.keyId))), { receiverDirectoryId: x.id }));
|
|
175
|
+
})),
|
|
176
|
+
...receiver.records.map((x) => __awaiter(this, void 0, void 0, function* () {
|
|
177
|
+
return (Object.assign(Object.assign({}, (yield prepareReceiverItem(x, x.record.keyId))), { receiverDirectoryId: x.id }));
|
|
178
|
+
})),
|
|
179
|
+
]);
|
|
180
|
+
return {
|
|
181
|
+
receiverId: receiver.id,
|
|
182
|
+
sharedKeyId: receiver.keyId,
|
|
183
|
+
receiverDirectories,
|
|
184
|
+
receiverFiles: [],
|
|
185
|
+
sharedCipherData: yield this.keyGraph.encryptToString(sharedKey.jwk, {
|
|
186
|
+
event,
|
|
187
|
+
message: receiver.message,
|
|
188
|
+
}),
|
|
189
|
+
};
|
|
190
|
+
})));
|
|
191
|
+
});
|
|
192
|
+
}
|
|
193
|
+
mapApprovalGroups(approvalGroups, quorum, assemblyKey) {
|
|
194
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
195
|
+
const slipAssembly = yield this.createSlipAssembly(quorum, approvalGroups, assemblyKey.toJSON(true).k);
|
|
196
|
+
return yield Promise.all(approvalGroups.map((x, index) => this.mapApprovalGroup(x, slipAssembly.subAssemblies[index], assemblyKey)));
|
|
197
|
+
});
|
|
198
|
+
}
|
|
199
|
+
mapApprovalGroup(approvalGroup, subAssembly, assemblyKey) {
|
|
200
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
201
|
+
const approvers = yield this.mapApprovers(approvalGroup.approvers, approvalGroup.quorum, subAssembly, assemblyKey);
|
|
202
|
+
return {
|
|
203
|
+
subAssemblyId: approvalGroup.subAssemblyId,
|
|
204
|
+
singleReject: approvalGroup.singleReject,
|
|
205
|
+
quorum: approvalGroup.quorum,
|
|
206
|
+
subAssemblyCipherData: yield this.keyGraph.encryptToString(assemblyKey, approvalGroup.plainSubAssemblyCipherData),
|
|
207
|
+
createApprovers: approvers.filter((x) => !x.approverId),
|
|
208
|
+
updateApprovers: approvers.filter((x) => x.approverId),
|
|
209
|
+
deleteApprovers: approvalGroup.deletedApproverIds || [],
|
|
210
|
+
};
|
|
211
|
+
});
|
|
212
|
+
}
|
|
213
|
+
mapApprovers(approvers, quorum, subAssembly, assemblyKey) {
|
|
214
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
215
|
+
const _a = assemblyKey.toJSON(true), { k: rawAssemblyKey } = _a, assemblyKeyParams = __rest(_a, ["k"]);
|
|
216
|
+
let shareIdx = 0;
|
|
217
|
+
const nextPartialAssemblyKey = (sharedKeyJwk) => __awaiter(this, void 0, void 0, function* () {
|
|
218
|
+
const share = subAssembly.shares[shareIdx];
|
|
219
|
+
// If quorum is 1, then using the same share for every member.
|
|
220
|
+
if (quorum !== 1) {
|
|
221
|
+
++shareIdx;
|
|
222
|
+
}
|
|
223
|
+
const partialAssemblyKey = {
|
|
224
|
+
slip39: {
|
|
225
|
+
share,
|
|
226
|
+
subAssembly: {
|
|
227
|
+
quorum,
|
|
228
|
+
size: approvers.length,
|
|
229
|
+
},
|
|
230
|
+
},
|
|
231
|
+
assemblyKeyParams,
|
|
232
|
+
};
|
|
233
|
+
return this.keyGraph.encryptToString(sharedKeyJwk, partialAssemblyKey);
|
|
234
|
+
});
|
|
235
|
+
return yield Promise.all(approvers.map((x) => __awaiter(this, void 0, void 0, function* () {
|
|
236
|
+
if (x.approverId) {
|
|
237
|
+
const sharedKey = yield this.keyGraph.getKey(x.keyId);
|
|
238
|
+
const sharedCipherData = yield this.keyGraph.encryptToString(x.keyId, x.plainSharedCipherData);
|
|
239
|
+
const sharedCipherApprovalData = yield this.keyGraph.encryptToString(x.keyId, x.approvalData);
|
|
240
|
+
return {
|
|
241
|
+
approverId: x.approverId,
|
|
242
|
+
sharedKeyId: x.keyId,
|
|
243
|
+
sharedCipherData: sharedCipherData || '',
|
|
244
|
+
sharedCipherApprovalData: sharedCipherApprovalData || '',
|
|
245
|
+
sharedCipherPartialAssemblyKey: yield nextPartialAssemblyKey(sharedKey.jwk),
|
|
246
|
+
};
|
|
247
|
+
}
|
|
248
|
+
else {
|
|
249
|
+
const wrappedContent = yield this.keyMetaService.wrapContentWithKey(x.plainSharedCipherData, x.trustedPartySharedKeyId);
|
|
250
|
+
return {
|
|
251
|
+
tpId: x.trustedPartyId,
|
|
252
|
+
tpSharedKeyId: x.trustedPartySharedKeyId,
|
|
253
|
+
tpSharedKeyWrappedSharedKey: wrappedContent.rootKey.wrappedKey,
|
|
254
|
+
sharedCipherData: wrappedContent.cipherMeta,
|
|
255
|
+
sharedCipherApprovalData: '',
|
|
256
|
+
sharedCipherPartialAssemblyKey: yield nextPartialAssemblyKey(wrappedContent.key),
|
|
257
|
+
};
|
|
258
|
+
}
|
|
259
|
+
})));
|
|
260
|
+
});
|
|
261
|
+
}
|
|
262
|
+
// Split assembly key between all existing approvers.
|
|
263
|
+
createSlipAssembly(quorum, approvalGroups, rawAssemblyKey) {
|
|
264
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
265
|
+
const slipAssembly = new slip.Assembly(quorum);
|
|
266
|
+
approvalGroups.forEach((x, index) => {
|
|
267
|
+
let approverCount = x.approvers.length;
|
|
268
|
+
// slip39 restricts quorum == 1 to have only 1 member. So we just share the same
|
|
269
|
+
// partial key for all sub assembly members.
|
|
270
|
+
if (x.quorum === 1) {
|
|
271
|
+
approverCount = 1;
|
|
272
|
+
}
|
|
273
|
+
slipAssembly.addSubAssembly(new slip.SubAssembly(index, x.quorum, approverCount));
|
|
274
|
+
});
|
|
275
|
+
// Is there enough sub assemblies to meet quorum
|
|
276
|
+
if (slipAssembly.subAssemblies.length < quorum) {
|
|
277
|
+
return null;
|
|
278
|
+
}
|
|
279
|
+
yield this.slip39Service.generateShares(rawAssemblyKey, ScenarioApproverService.SLIP39_PASSPHRASE, slipAssembly);
|
|
280
|
+
return slipAssembly;
|
|
281
|
+
});
|
|
282
|
+
}
|
|
283
|
+
}
|
|
284
|
+
ScenarioApproverService.SLIP39_PASSPHRASE = 'lifeready';
|
|
285
|
+
ScenarioApproverService.ɵprov = i0.ɵɵdefineInjectable({ factory: function ScenarioApproverService_Factory() { return new ScenarioApproverService(i0.ɵɵinject(i1.LrApolloService), i0.ɵɵinject(i2.KeyFactoryService), i0.ɵɵinject(i3.KeyMetaService), i0.ɵɵinject(i4.KeyGraphService), i0.ɵɵinject(i5.Slip39Service), i0.ɵɵinject(i6.EncryptionService), i0.ɵɵinject(i7.TrustedPartyService)); }, token: ScenarioApproverService, providedIn: "root" });
|
|
286
|
+
ScenarioApproverService.decorators = [
|
|
287
|
+
{ type: Injectable, args: [{
|
|
288
|
+
providedIn: 'root',
|
|
289
|
+
},] }
|
|
290
|
+
];
|
|
291
|
+
ScenarioApproverService.ctorParameters = () => [
|
|
292
|
+
{ type: LrApolloService },
|
|
293
|
+
{ type: KeyFactoryService },
|
|
294
|
+
{ type: KeyMetaService },
|
|
295
|
+
{ type: KeyGraphService },
|
|
296
|
+
{ type: slip.Slip39Service },
|
|
297
|
+
{ type: EncryptionService },
|
|
298
|
+
{ type: TrustedPartyService }
|
|
299
|
+
];
|
|
300
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NlbmFyaW8tYXBwcm92ZXIuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiJDOi9Qcm9qZWN0cy9uZXdyZXBvL2tjLWNsaWVudC9wcm9qZWN0cy9jb3JlL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9zY2VuYXJpby9hcHByb3ZhbHMvc2NlbmFyaW8tYXBwcm92ZXIuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUzQyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDOUQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDMUUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sd0NBQXdDLENBQUM7QUFDM0UsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUNyRSxPQUFPLEtBQUssSUFBSSxNQUFNLG1DQUFtQyxDQUFDO0FBQzFELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLDZDQUE2QyxDQUFDO0FBT2xGLE9BQU8sRUFDTCxzQ0FBc0MsRUFDdEMsc0NBQXNDLEVBQ3RDLHdCQUF3QixFQUN4QixzQ0FBc0MsRUFDdEMsOEJBQThCLEdBQy9CLE1BQU0seUJBQXlCLENBQUM7Ozs7Ozs7OztBQWFqQyxNQUFNLE9BQU8sdUJBQXVCO0lBR2xDLFlBQ1UsUUFBeUIsRUFDekIsVUFBNkIsRUFDN0IsY0FBOEIsRUFDOUIsUUFBeUIsRUFDekIsYUFBaUMsRUFDakMsaUJBQW9DLEVBQ3BDLG1CQUF3QztRQU54QyxhQUFRLEdBQVIsUUFBUSxDQUFpQjtRQUN6QixlQUFVLEdBQVYsVUFBVSxDQUFtQjtRQUM3QixtQkFBYyxHQUFkLGNBQWMsQ0FBZ0I7UUFDOUIsYUFBUSxHQUFSLFFBQVEsQ0FBaUI7UUFDekIsa0JBQWEsR0FBYixhQUFhLENB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b3JlJztcclxuaW1wb3J0IHsgSldLIH0gZnJvbSAnbm9kZS1qb3NlJztcclxuaW1wb3J0IHsgTHJBcG9sbG9TZXJ2aWNlIH0gZnJvbSAnLi4vLi4vYXBpL2xyLWFwb2xsby5zZXJ2aWNlJztcclxuaW1wb3J0IHsgRW5jcnlwdGlvblNlcnZpY2UgfSBmcm9tICcuLi8uLi9jcnlwdG9ncmFwaHkvZW5jcnlwdGlvbi5zZXJ2aWNlJztcclxuaW1wb3J0IHsgS2V5RmFjdG9yeVNlcnZpY2UgfSBmcm9tICcuLi8uLi9jcnlwdG9ncmFwaHkva2V5LWZhY3Rvcnkuc2VydmljZSc7XHJcbmltcG9ydCB7IEtleUdyYXBoU2VydmljZSB9IGZyb20gJy4uLy4uL2NyeXB0b2dyYXBoeS9rZXktZ3JhcGguc2VydmljZSc7XHJcbmltcG9ydCB7IEtleU1ldGFTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vY3J5cHRvZ3JhcGh5L2tleS1tZXRhLnNlcnZpY2UnO1xyXG5pbXBvcnQgKiBhcyBzbGlwIGZyb20gJy4uLy4uL2NyeXB0b2dyYXBoeS9zbGlwMzkuc2VydmljZSc7XHJcbmltcG9ydCB7IFRydXN0ZWRQYXJ0eVNlcnZpY2UgfSBmcm9tICcuLi8uLi90cnVzdGVkLXBhcnRpZXMvdHJ1c3RlZC1wYXJ0eS5zZXJ2aWNlJztcclxuaW1wb3J0IHtcclxuICBSZWNlaXZlcixcclxuICBSZWNlaXZlckNhdGVnb3J5LFxyXG4gIFJlY2VpdmVyUmVjb3JkLFxyXG59IGZyb20gJy4uL3JlY2VpdmVycy9zY2VuYXJpby1yZWNlaXZlci50eXBlcyc7XHJcbmltcG9ydCB7IFBhcnRpYWxBc3NlbWJseUtleSB9IGZyb20gJy4uL3NjZW5hcmlvLnR5cGVzJztcclxuaW1wb3J0IHtcclxuICBDcmVhdGVTY2VuYXJpb0FwcHJvdmVyQXNzZW1ibHlNdXRhdGlvbixcclxuICBEZWxldGVTY2VuYXJpb0FwcHJvdmVyQXNzZW1ibHlNdXRhdGlvbixcclxuICBHZXRTY2VuYXJpb0FwcHJvdmVyUXVlcnksXHJcbiAgVXBkYXRlU2NlbmFyaW9BcHByb3ZlckFzc2VtYmx5TXV0YXRpb24sXHJcbiAgVXBkYXRlU2NlbmFyaW9BcHByb3Zlck11dGF0aW9uLFxyXG59IGZyb20gJy4vc2NlbmFyaW8tYXBwcm92YWwuZ3FsJztcclxuaW1wb3J0IHtcclxuICBBcHByb3ZhbEdyb3VwLFxyXG4gIEFwcHJvdmVyLFxyXG4gIENyZWF0ZVNjZW5hcmlvQXBwcm92YWxHcm91cHMsXHJcbiAgVXBkYXRlU2NlbmFyaW9BcHByb3ZhbEdyb3VwLFxyXG4gIFVwZGF0ZVNjZW5hcmlvQXBwcm92YWxHcm91cHMsXHJcbiAgVXBkYXRlU2NlbmFyaW9BcHByb3ZlcixcclxufSBmcm9tICcuL3NjZW5hcmlvLWFwcHJvdmFsLnR5cGVzJztcclxuXHJcbkBJbmplY3RhYmxlKHtcclxuICBwcm92aWRlZEluOiAncm9vdCcsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBTY2VuYXJpb0FwcHJvdmVyU2VydmljZSB7XHJcbiAgcHVibGljIHN0YXRpYyBTTElQMzlfUEFTU1BIUkFTRSA9ICdsaWZlcmVhZHknO1xyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByaXZhdGUgbHJBcG9sbG86IExyQXBvbGxvU2VydmljZSxcclxuICAgIHByaXZhdGUga2V5RmFjdG9yeTogS2V5RmFjdG9yeVNlcnZpY2UsXHJcbiAgICBwcml2YXRlIGtleU1ldGFTZXJ2aWNlOiBLZXlNZXRhU2VydmljZSxcclxuICAgIHByaXZhdGUga2V5R3JhcGg6IEtleUdyYXBoU2VydmljZSxcclxuICAgIHByaXZhdGUgc2xpcDM5U2VydmljZTogc2xpcC5TbGlwMzlTZXJ2aWNlLFxyXG4gICAgcHJpdmF0ZSBlbmNyeXB0aW9uU2VydmljZTogRW5jcnlwdGlvblNlcnZpY2UsXHJcbiAgICBwcml2YXRlIHRydXN0ZWRQYXJ0eVNlcnZpY2U6IFRydXN0ZWRQYXJ0eVNlcnZpY2VcclxuICApIHt9XHJcblxyXG4gIHB1YmxpYyBhc3luYyBnZXRBcHByb3ZlcihhcHByb3ZlcklkOiBzdHJpbmcpOiBQcm9taXNlPEFwcHJvdmVyPiB7XHJcbiAgICBjb25zdCB7IHNjZW5hcmlvQXBwcm92ZXIgfSA9IGF3YWl0IHRoaXMubHJBcG9sbG8ucXVlcnk8YW55Pih7XHJcbiAgICAgIHF1ZXJ5OiBHZXRTY2VuYXJpb0FwcHJvdmVyUXVlcnksXHJcbiAgICAgIHZhcmlhYmxlczoge1xyXG4gICAgICAgIGlkOiBhcHByb3ZlcklkLFxyXG4gICAgICB9LFxyXG4gICAgfSk7XHJcbiAgICByZXR1cm4gdGhpcy5tYXBBcHByb3ZlcihzY2VuYXJpb0FwcHJvdmVyKTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBhc3luYyBtYXBBcHByb3Zlckdyb3VwKGdyb3VwOiBhbnkpOiBQcm9taXNlPEFwcHJvdmFsR3JvdXA+IHtcclxuICAgIGNvbnN0IHsgbmFtZSB9ID0gYXdhaXQgdGhpcy5rZXlHcmFwaC5kZWNyeXB0RnJvbVN0cmluZzx7XHJcbiAgICAgIG5hbWU6IHN0cmluZztcclxuICAgIH0+KGdyb3VwLmFzc2VtYmx5S2V5LmlkLCBncm91cC5zdWJBc3NlbWJseUNpcGhlckRhdGEpO1xyXG5cclxuICAgIHJldHVybiB7XHJcbiAgICAgIGlkOiBncm91cC5pZCxcclxuICAgICAga2V5SWQ6IGdyb3VwLmFzc2VtYmx5S2V5LmlkLFxyXG4gICAgICBuYW1lLFxyXG4gICAgICBxdW9ydW06IGdyb3VwLnF1b3J1bSxcclxuICAgICAgc2luZ2xlUmVqZWN0OiBncm91cC5zaW5nbGVSZWplY3QsXHJcbiAgICAgIGFwcHJvdmVyczogYXdhaXQgUHJvbWlzZS5hbGwoXHJcbiAgICAgICAgZ3JvdXAuYXBwcm92ZXJzLmVkZ2VzLm1hcCgoeCkgPT4gdGhpcy5tYXBBcHByb3Zlcih4Lm5vZGUpKVxyXG4gICAgICApLFxyXG4gICAgfTtcclxuICB9XHJcblxyXG4gIHByaXZhdGUgYXN5bmMgbWFwQXBwcm92ZXIoYXBwcm92ZXI6IGFueSk6IFByb21pc2U8QXBwcm92ZXI+IHtcclxuICAgIGNvbnN0IHsgbWVzc2FnZSB9ID0gYXdhaXQgdGhpcy5rZXlHcmFwaC5kZWNyeXB0RnJvbVN0cmluZzx7XHJcbiAgICAgIG1lc3NhZ2U6IHN0cmluZztcclxuICAgIH0+KGFwcHJvdmVyLnNoYXJlZEtleS5pZCwgYXBwcm92ZXIuc2hhcmVkQ2lwaGVyRGF0YSk7XHJcblxyXG4gICAgcmV0dXJuIHtcclxuICAgICAgaWQ6IGFwcHJvdmVyLmlkLFxyXG4gICAgICBrZXlJZDogYXBwcm92ZXIuc2hhcmVkS2V5LmlkLFxyXG4gICAgICB0cnVzdGVkUGFydHk6IGF3YWl0IHRoaXMudHJ1c3RlZFBhcnR5U2VydmljZS5tYXBUcnVzdGVkUGFydHkoYXBwcm92ZXIudHApLFxyXG4gICAgICBtZXNzYWdlLFxyXG4gICAgfTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBhc3luYyB1cGRhdGVBcHByb3ZlcihhcHByb3ZlcjogVXBkYXRlU2NlbmFyaW9BcHByb3Zlcik6IFByb21pc2U8dm9pZD4ge1xyXG4gICAgY29uc3Qgc2hhcmVkQ2lwaGVyRGF0YSA9IGF3YWl0IHRoaXMua2V5R3JhcGguZW5jcnlwdFRvU3RyaW5nKFxyXG4gICAgICBhcHByb3Zlci5rZXlJZCxcclxuICAgICAgYXBwcm92ZXIucGxhaW5TaGFyZWRDaXBoZXJEYXRhXHJcbiAgICApO1xyXG5cclxuICAgIGF3YWl0IHRoaXMubHJBcG9sbG8ubXV0YXRlPGFueT4oe1xyXG4gICAgICBtdXRhdGlvbjogVXBkYXRlU2NlbmFyaW9BcHByb3Zlck11dGF0aW9uLFxyXG4gICAgICB2YXJpYWJsZXM6IHtcclxuICAgICAgICBpbnB1dDoge1xyXG4gICAgICAgICAgYXBwcm92ZXJJZDogYXBwcm92ZXIuYXBwcm92ZXJJZCxcclxuICAgICAgICAgIHNoYXJlZEtleUlkOiBhcHByb3Zlci5rZXlJZCxcclxuICAgICAgICAgIHNoYXJlZENpcGhlckRhdGEsXHJcbiAgICAgICAgICBzaGFyZWRDaXBoZXJBcHByb3ZhbERhdGE6ICcnLFxyXG4gICAgICAgIH0sXHJcbiAgICAgIH0sXHJcbiAgICB9KTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBhc3luYyBjcmVhdGVTY2VuYXJpb0FwcHJvdmVyQXNzZW1ibHkoXHJcbiAgICBpbnB1dDogQ3JlYXRlU2NlbmFyaW9BcHByb3ZhbEdyb3Vwc1xyXG4gICk6IFByb21pc2U8c3RyaW5nPiB7XHJcbiAgICBjb25zdCBhc3NlbWJseUtleSA9IGF3YWl0IHRoaXMua2V5RmFjdG9yeS5jcmVhdGVLZXkoKTtcclxuXHJcbiAgICBjb25zdCBzdWJqZWN0S2V5V3JhcHBlZEFzc2VtYmx5S2V5ID0gYXdhaXQgdGhpcy5rZXlHcmFwaC5lbmNyeXB0VG9TdHJpbmcoXHJcbiAgICAgIGlucHV0LmtleUlkLFxyXG4gICAgICBhc3NlbWJseUtleS50b0pTT04odHJ1ZSlcclxuICAgICk7XHJcblxyXG4gICAgY29uc3QgYXNzZW1ibHlDaXBoZXJEYXRhID0gaW5wdXQucGxhaW5Bc3NlbWJseUNpcGhlckRhdGFcclxuICAgICAgPyBhd2FpdCB0aGlzLmtleUdyYXBoLmVuY3J5cHRUb1N0cmluZyhcclxuICAgICAgICAgIGFzc2VtYmx5S2V5LFxyXG4gICAgICAgICAgaW5wdXQucGxhaW5Bc3NlbWJseUNpcGhlckRhdGFcclxuICAgICAgICApXHJcbiAgICAgIDogJyc7XHJcblxyXG4gICAgY29uc3QgeyBjcmVhdGVTY2VuYXJpb0FwcHJvdmVyQXNzZW1ibHkgfSA9IGF3YWl0IHRoaXMubHJBcG9sbG8ubXV0YXRlPGFueT4oe1xyXG4gICAgICBtdXRhdGlvbjogQ3JlYXRlU2NlbmFyaW9BcHByb3ZlckFzc2VtYmx5TXV0YXRpb24sXHJcbiAgICAgIHZhcmlhYmxlczoge1xyXG4gICAgICAgIGlucHV0OiB7XHJcbiAgICAgICAgICBzY2VuYXJpb0lkOiBpbnB1dC5zY2VuYXJpb0lkLFxyXG4gICAgICAgICAgc2luZ2xlUmVqZWN0OiBpbnB1dC5zaW5nbGVSZWplY3QsXHJcbiAgICAgICAgICBxdW9ydW06IGlucHV0LnF1b3J1bSxcclxuICAgICAgICAgIHN1YmplY3RLZXlJZDogaW5wdXQua2V5SWQsXHJcbiAgICAgICAgICBzdWJqZWN0S2V5V3JhcHBlZEFzc2VtYmx5S2V5LFxyXG4gICAgICAgICAgYXNzZW1ibHlDaXBoZXJEYXRhLFxyXG4gICAgICAgICAgY3JlYXRlU3ViQXNzZW1ibGllczogKFxyXG4gICAgICAgICAgICBhd2FpdCB0aGlzLm1hcEFwcHJvdmFsR3JvdXBzKFxyXG4gICAgICAgICAgICAgIGlucHV0LmFwcHJvdmFsR3JvdXBzLFxyXG4gICAgICAgICAgICAgIGlucHV0LnF1b3J1bSxcclxuICAgICAgICAgICAgICBhc3NlbWJseUtleVxyXG4gICAgICAgICAgICApXHJcbiAgICAgICAgICApLm1hcCgoeCkgPT4ge1xyXG4gICAgICAgICAgICBjb25zdCB7IHVwZGF0ZUFwcHJvdmVycywgZGVsZXRlQXBwcm92ZXJzLCAuLi5zdWJBc3NlbWJseSB9ID0geDtcclxuICAgICAgICAgICAgcmV0dXJuIHN1YkFzc2VtYmx5O1xyXG4gICAgICAgICAgfSksXHJcbiAgICAgICAgICB1cGRhdGVSZWNlaXZlcnM6IGF3YWl0IHRoaXMucmV3cmFwUmVjZWl2ZXJzKFxyXG4gICAgICAgICAgICBhc3NlbWJseUtleSxcclxuICAgICAgICAgICAgaW5wdXQuZXZlbnQsXHJcbiAgICAgICAgICAgIGlucHV0LnJlY2VpdmVyc1xyXG4gICAgICAgICAgKSxcclxuICAgICAgICB9LFxyXG4gICAgICB9LFxyXG4gICAgfSk7XHJcbiAgICByZXR1cm4gY3JlYXRlU2NlbmFyaW9BcHByb3ZlckFzc2VtYmx5LnNjZW5hcmlvLmFwcHJvdmVyQXNzZW1ibHkuYXNzZW1ibHlLZXlcclxuICAgICAgLmlkO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGFzeW5jIHVwZGF0ZVNjZW5hcmlvQXBwcm92ZXJBc3NlbWJseShcclxuICAgIGlucHV0OiBVcGRhdGVTY2VuYXJpb0FwcHJvdmFsR3JvdXBzXHJcbiAgKTogUHJvbWlzZTx2b2lkPiB7XHJcbiAgICBjb25zdCBhc3NlbWJseUtleSA9IGF3YWl0IHRoaXMua2V5R3JhcGguZ2V0S2V5KGlucHV0LmFzc2VtYmx5S2V5SWQpO1xyXG4gICAgY29uc3QgYXNzZW1ibHlDaXBoZXJEYXRhID0gaW5wdXQucGxhaW5Bc3NlbWJseUNpcGhlckRhdGFcclxuICAgICAgPyBhd2FpdCB0aGlzLmtleUdyYXBoLmVuY3J5cHRUb1N0cmluZyhcclxuICAgICAgICAgIGFzc2VtYmx5S2V5Lmp3ayxcclxuICAgICAgICAgIGlucHV0LnBsYWluQXNzZW1ibHlDaXBoZXJEYXRhXHJcbiAgICAgICAgKVxyXG4gICAgICA6ICcnO1xyXG5cclxuICAgIGNvbnN0IGFwcHJvdmFsR3JvdXBzID0gYXdhaXQgdGhpcy5tYXBBcHByb3ZhbEdyb3VwcyhcclxuICAgICAgaW5wdXQuYXBwcm92YWxHcm91cHMsXHJcbiAgICAgIGlucHV0LnF1b3J1bSxcclxuICAgICAgYXNzZW1ibHlLZXkuandrXHJcbiAgICApO1xyXG5cclxuICAgIGF3YWl0IHRoaXMubHJBcG9sbG8ubXV0YXRlPGFueT4oe1xyXG4gICAgICBtdXRhdGlvbjogVXBkYXRlU2NlbmFyaW9BcHByb3ZlckFzc2VtYmx5TXV0YXRpb24sXHJcbiAgICAgIHZhcmlhYmxlczoge1xyXG4gICAgICAgIGlucHV0OiB7XHJcbiAgICAgICAgICBzY2VuYXJpb0lkOiBpbnB1dC5zY2VuYXJpb0lkLFxyXG4gICAgICAgICAgc2luZ2xlUmVqZWN0OiBpbnB1dC5zaW5nbGVSZWplY3QsXHJcbiAgICAgICAgICBxdW9ydW06IGlucHV0LnF1b3J1bSxcclxuICAgICAgICAgIGFzc2VtYmx5S2V5SWQ6IGFzc2VtYmx5S2V5LmlkLFxyXG4gICAgICAgICAgYXNzZW1ibHlDaXBoZXJEYXRhLFxyXG4gICAgICAgICAgY3JlYXRlU3ViQXNzZW1ibGllczogYXBwcm92YWxHcm91cHNcclxuICAgICAgICAgICAgLmZpbHRlcigoeCkgPT4gIXguc3ViQXNzZW1ibHlJZClcclxuICAgICAgICAgICAgLm1hcCgoeCkgPT4ge1xyXG4gICAgICAgICAgICAgIGNvbnN0IHsgdXBkYXRlQXBwcm92ZXJzLCBkZWxldGVBcHByb3ZlcnMsIC4uLnN1YkFzc2VtYmx5IH0gPSB4O1xyXG4gICAgICAgICAgICAgIHJldHVybiBzdWJBc3NlbWJseTtcclxuICAgICAgICAgICAgfSksXHJcbiAgICAgICAgICB1cGRhdGVTdWJBc3NlbWJsaWVzOiBhcHByb3ZhbEdyb3Vwcy5maWx0ZXIoKHgpID0+IHguc3ViQXNzZW1ibHlJZCksXHJcbiAgICAgICAgICBkZWxldGVTdWJBc3NlbWJsaWVzOiBpbnB1dC5kZWxldGVkR3JvdXBJZHMsXHJcbiAgICAgICAgfSxcclxuICAgICAgfSxcclxuICAgIH0pO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGFzeW5jIGRlbGV0ZVNjZW5hcmlvQXBwcm92ZXJBc3NlbWJseShcclxuICAgIHNjZW5hcmlvSWQ6IHN0cmluZyxcclxuICAgIGV2ZW50OiBzdHJpbmcsXHJcbiAgICByZWNlaXZlcnM6IFJlY2VpdmVyW11cclxuICApOiBQcm9taXNlPHZvaWQ+IHtcclxuICAgIGF3YWl0IHRoaXMubHJBcG9sbG8ubXV0YXRlPGFueT4oe1xyXG4gICAgICBtdXRhdGlvbjogRGVsZXRlU2NlbmFyaW9BcHByb3ZlckFzc2VtYmx5TXV0YXRpb24sXHJcbiAgICAgIHZhcmlhYmxlczoge1xyXG4gICAgICAgIGlucHV0OiB7XHJcbiAgICAgICAgICBzY2VuYXJpb0lkLFxyXG4gICAgICAgICAgdXBkYXRlUmVjZWl2ZXJzOiBhd2FpdCB0aGlzLnJld3JhcFJlY2VpdmVycyhudWxsLCBldmVudCwgcmVjZWl2ZXJzKSxcclxuICAgICAgICB9LFxyXG4gICAgICB9LFxyXG4gICAgfSk7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIGFzeW5jIHJld3JhcFJlY2VpdmVycyhcclxuICAgIGFzc2VtYmx5S2V5OiBKV0suS2V5LFxyXG4gICAgZXZlbnQ6IHN0cmluZyxcclxuICAgIHJlY2VpdmVyczogUmVjZWl2ZXJbXVxyXG4gICkge1xyXG4gICAgaWYgKCFyZWNlaXZlcnMgfHwgIXJlY2VpdmVycy5sZW5ndGgpIHtcclxuICAgICAgcmV0dXJuIFtdO1xyXG4gICAgfVxyXG5cclxuICAgIHJldHVybiBhd2FpdCBQcm9taXNlLmFsbChcclxuICAgICAgcmVjZWl2ZXJzLm1hcChhc3luYyAocmVjZWl2ZXIpID0+IHtcclxuICAgICAgICBjb25zdCBzaGFyZWRLZXkgPSBhd2FpdCB0aGlzLmtleUdyYXBoLmdldEtleShyZWNlaXZlci5rZXlJZCk7XHJcblxyXG4gICAgICAgIGNvbnN0IHByZXBhcmVSZWNlaXZlckl0ZW0gPSBhc3luYyAoXHJcbiAgICAgICAgICBpdGVtOiBSZWNlaXZlckNhdGVnb3J5IHwgUmVjZWl2ZXJSZWNvcmQsXHJcbiAgICAgICAgICBpdGVtS2V5SWQ6IHN0cmluZ1xyXG4gICAgICAgICkgPT4ge1xyXG4gICAgICAgICAgY29uc3QgaXRlbUtleSA9IGF3YWl0IHRoaXMua2V5R3JhcGguZ2V0S2V5KGl0ZW1LZXlJZCk7XHJcbiAgICAgICAgICBsZXQgd3JhcHBlZEl0ZW1LZXkgPSBhd2FpdCB0aGlzLmtleUdyYXBoLmVuY3J5cHRUb1N0cmluZyhcclxuICAgICAgICAgICAgc2hhcmVkS2V5Lmp3ayxcclxuICAgICAgICAgICAgaXRlbUtleS5qd2sudG9KU09OKHRydWUpXHJcbiAgICAgICAgICApO1xyXG5cclxuICAgICAgICAgIGlmIChhc3NlbWJseUtleSkge1xyXG4gICAgICAgICAgICB3cmFwcGVkSXRlbUtleSA9IGF3YWl0IHRoaXMua2V5R3JhcGguZW5jcnlwdFRvU3RyaW5nKFxyXG4gICAgICAgICAgICAgIGFzc2VtYmx5S2V5LFxyXG4gICAgICAgICAgICAgIHdyYXBwZWRJdGVtS2V5XHJcbiAgICAgICAgICAgICk7XHJcbiAgICAgICAgICB9XHJcblxyXG4gICAgICAgICAgcmV0dXJuIHtcclxuICAgICAgICAgICAgYWNjZXNzUm9sZTogaXRlbS5hY2Nlc3NMZXZlbCxcclxuICAgICAgICAgICAgc2hhcmVkS2V5SWQ6IHNoYXJlZEtleS5pZCxcclxuICAgICAgICAgICAgc2hhcmVkQ2lwaGVyRGF0YTogJycsXHJcbiAgICAgICAgICAgIHdyYXBwZWRJdGVtS2V5LFxyXG4gICAgICAgICAgfTtcclxuICAgICAgICB9O1xyXG5cclxuICAgICAgICAvLyBGb3IgZWFjaCByZWNlaXZlci1kaXJlY3RvcnlcclxuICAgICAgICBjb25zdCByZWNlaXZlckRpcmVjdG9yaWVzID0gYXdhaXQgUHJvbWlzZS5hbGwoW1xyXG4gICAgICAgICAgLi4ucmVjZWl2ZXIuY2F0ZWdvcmllcy5tYXAoYXN5bmMgKHgpID0+ICh7XHJcbiAgICAgICAgICAgIC4uLihhd2FpdCBwcmVwYXJlUmVjZWl2ZXJJdGVtKHgsIHguY2F0ZWdvcnkua2V5SWQpKSxcclxuICAgICAgICAgICAgcmVjZWl2ZXJEaXJlY3RvcnlJZDogeC5pZCxcclxuICAgICAgICAgIH0pKSxcclxuICAgICAgICAgIC4uLnJlY2VpdmVyLnJlY29yZHMubWFwKGFzeW5jICh4KSA9PiAoe1xyXG4gICAgICAgICAgICAuLi4oYXdhaXQgcHJlcGFyZVJlY2VpdmVySXRlbSh4LCB4LnJlY29yZC5rZXlJZCkpLFxyXG4gICAgICAgICAgICByZWNlaXZlckRpcmVjdG9yeUlkOiB4LmlkLFxyXG4gICAgICAgICAgfSkpLFxyXG4gICAgICAgIF0pO1xyXG5cclxuICAgICAgICByZXR1cm4ge1xyXG4gICAgICAgICAgcmVjZWl2ZXJJZDogcmVjZWl2ZXIuaWQsXHJcbiAgICAgICAgICBzaGFyZWRLZXlJZDogcmVjZWl2ZXIua2V5SWQsXHJcbiAgICAgICAgICByZWNlaXZlckRpcmVjdG9yaWVzLFxyXG4gICAgICAgICAgcmVjZWl2ZXJGaWxlczogW10sXHJcbiAgICAgICAgICBzaGFyZWRDaXBoZXJEYXRhOiBhd2FpdCB0aGlzLmtleUdyYXBoLmVuY3J5cHRUb1N0cmluZyhzaGFyZWRLZXkuandrLCB7XHJcbiAgICAgICAgICAgIGV2ZW50LFxyXG4gICAgICAgICAgICBtZXNzYWdlOiByZWNlaXZlci5tZXNzYWdlLFxyXG4gICAgICAgICAgfSksXHJcbiAgICAgICAgfTtcclxuICAgICAgfSlcclxuICAgICk7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIGFzeW5jIG1hcEFwcHJvdmFsR3JvdXBzKFxyXG4gICAgYXBwcm92YWxHcm91cHM6IFVwZGF0ZVNjZW5hcmlvQXBwcm92YWxHcm91cFtdLFxyXG4gICAgcXVvcnVtOiBudW1iZXIsXHJcbiAgICBhc3NlbWJseUtleTogSldLLktleVxyXG4gICkge1xyXG4gICAgY29uc3Qgc2xpcEFzc2VtYmx5ID0gYXdhaXQgdGhpcy5jcmVhdGVTbGlwQXNzZW1ibHkoXHJcbiAgICAgIHF1b3J1bSxcclxuICAgICAgYXBwcm92YWxHcm91cHMsXHJcbiAgICAgIChhc3NlbWJseUtleS50b0pTT04odHJ1ZSkgYXMgYW55KS5rXHJcbiAgICApO1xyXG4gICAgcmV0dXJuIGF3YWl0IFByb21pc2UuYWxsKFxyXG4gICAgICBhcHByb3ZhbEdyb3Vwcy5tYXAoKHgsIGluZGV4KSA9PlxyXG4gICAgICAgIHRoaXMubWFwQXBwcm92YWxHcm91cCh4LCBzbGlwQXNzZW1ibHkuc3ViQXNzZW1ibGllc1tpbmRleF0sIGFzc2VtYmx5S2V5KVxyXG4gICAgICApXHJcbiAgICApO1xyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSBhc3luYyBtYXBBcHByb3ZhbEdyb3VwKFxyXG4gICAgYXBwcm92YWxHcm91cDogVXBkYXRlU2NlbmFyaW9BcHByb3ZhbEdyb3VwLFxyXG4gICAgc3ViQXNzZW1ibHk6IHNsaXAuU3ViQXNzZW1ibHksXHJcbiAgICBhc3NlbWJseUtleTogSldLLktleVxyXG4gICkge1xyXG4gICAgY29uc3QgYXBwcm92ZXJzID0gYXdhaXQgdGhpcy5tYXBBcHByb3ZlcnMoXHJcbiAgICAgIGFwcHJvdmFsR3JvdXAuYXBwcm92ZXJzLFxyXG4gICAgICBhcHByb3ZhbEdyb3VwLnF1b3J1bSxcclxuICAgICAgc3ViQXNzZW1ibHksXHJcbiAgICAgIGFzc2VtYmx5S2V5XHJcbiAgICApO1xyXG5cclxuICAgIHJldHVybiB7XHJcbiAgICAgIHN1YkFzc2VtYmx5SWQ6IGFwcHJvdmFsR3JvdXAuc3ViQXNzZW1ibHlJZCxcclxuICAgICAgc2luZ2xlUmVqZWN0OiBhcHByb3ZhbEdyb3VwLnNpbmdsZVJlamVjdCxcclxuICAgICAgcXVvcnVtOiBhcHByb3ZhbEdyb3VwLnF1b3J1bSxcclxuICAgICAgc3ViQXNzZW1ibHlDaXBoZXJEYXRhOiBhd2FpdCB0aGlzLmtleUdyYXBoLmVuY3J5cHRUb1N0cmluZyhcclxuICAgICAgICBhc3NlbWJseUtleSxcclxuICAgICAgICBhcHByb3ZhbEdyb3VwLnBsYWluU3ViQXNzZW1ibHlDaXBoZXJEYXRhXHJcbiAgICAgICksXHJcbiAgICAgIGNyZWF0ZUFwcHJvdmVyczogYXBwcm92ZXJzLmZpbHRlcigoeCkgPT4gIXguYXBwcm92ZXJJZCksXHJcbiAgICAgIHVwZGF0ZUFwcHJvdmVyczogYXBwcm92ZXJzLmZpbHRlcigoeCkgPT4geC5hcHByb3ZlcklkKSxcclxuICAgICAgZGVsZXRlQXBwcm92ZXJzOiBhcHByb3ZhbEdyb3VwLmRlbGV0ZWRBcHByb3ZlcklkcyB8fCBbXSxcclxuICAgIH07XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIGFzeW5jIG1hcEFwcHJvdmVycyhcclxuICAgIGFwcHJvdmVyczogVXBkYXRlU2NlbmFyaW9BcHByb3ZlcltdLFxyXG4gICAgcXVvcnVtOiBudW1iZXIsXHJcbiAgICBzdWJBc3NlbWJseTogc2xpcC5TdWJBc3NlbWJseSxcclxuICAgIGFzc2VtYmx5S2V5OiBKV0suS2V5XHJcbiAgKSB7XHJcbiAgICBjb25zdCB7IGs6IHJhd0Fzc2VtYmx5S2V5LCAuLi5hc3NlbWJseUtleVBhcmFtcyB9ID0gYXNzZW1ibHlLZXkudG9KU09OKFxyXG4gICAgICB0cnVlXHJcbiAgICApIGFzIGFueTtcclxuICAgIGxldCBzaGFyZUlkeCA9IDA7XHJcblxyXG4gICAgY29uc3QgbmV4dFBhcnRpYWxBc3NlbWJseUtleSA9IGFzeW5jIChzaGFyZWRLZXlKd2s6IEpXSy5LZXkpID0+IHtcclxuICAgICAgY29uc3Qgc2hhcmUgPSBzdWJBc3NlbWJseS5zaGFyZXNbc2hhcmVJZHhdO1xyXG4gICAgICAvLyBJZiBxdW9ydW0gaXMgMSwgdGhlbiB1c2luZyB0aGUgc2FtZSBzaGFyZSBmb3IgZXZlcnkgbWVtYmVyLlxyXG4gICAgICBpZiAocXVvcnVtICE9PSAxKSB7XHJcbiAgICAgICAgKytzaGFyZUlkeDtcclxuICAgICAgfVxyXG4gICAgICBjb25zdCBwYXJ0aWFsQXNzZW1ibHlLZXk6IFBhcnRpYWxBc3NlbWJseUtleSA9IHtcclxuICAgICAgICBzbGlwMzk6IHtcclxuICAgICAgICAgIHNoYXJlLFxyXG4gICAgICAgICAgc3ViQXNzZW1ibHk6IHtcclxuICAgICAgICAgICAgcXVvcnVtLFxyXG4gICAgICAgICAgICBzaXplOiBhcHByb3ZlcnMubGVuZ3RoLFxyXG4gICAgICAgICAgfSxcclxuICAgICAgICB9LFxyXG4gICAgICAgIGFzc2VtYmx5S2V5UGFyYW1zLFxyXG4gICAgICB9O1xyXG4gICAgICByZXR1cm4gdGhpcy5rZXlHcmFwaC5lbmNyeXB0VG9TdHJpbmcoc2hhcmVkS2V5SndrLCBwYXJ0aWFsQXNzZW1ibHlLZXkpO1xyXG4gICAgfTtcclxuXHJcbiAgICByZXR1cm4gYXdhaXQgUHJvbWlzZS5hbGwoXHJcbiAgICAgIGFwcHJvdmVycy5tYXAoYXN5bmMgKHgpID0+IHtcclxuICAgICAgICBpZiAoeC5hcHByb3ZlcklkKSB7XHJcbiAgICAgICAgICBjb25zdCBzaGFyZWRLZXkgPSBhd2FpdCB0aGlzLmtleUdyYXBoLmdldEtleSh4LmtleUlkKTtcclxuICAgICAgICAgIGNvbnN0IHNoYXJlZENpcGhlckRhdGEgPSBhd2FpdCB0aGlzLmtleUdyYXBoLmVuY3J5cHRUb1N0cmluZyhcclxuICAgICAgICAgICAgeC5rZXlJZCxcclxuICAgICAgICAgICAgeC5wbGFpblNoYXJlZENpcGhlckRhdGFcclxuICAgICAgICAgICk7XHJcbiAgICAgICAgICBjb25zdCBzaGFyZWRDaXBoZXJBcHByb3ZhbERhdGEgPSBhd2FpdCB0aGlzLmtleUdyYXBoLmVuY3J5cHRUb1N0cmluZyhcclxuICAgICAgICAgICAgeC5rZXlJZCxcclxuICAgICAgICAgICAgeC5hcHByb3ZhbERhdGFcclxuICAgICAgICAgICk7XHJcblxyXG4gICAgICAgICAgcmV0dXJuIHtcclxuICAgICAgICAgICAgYXBwcm92ZXJJZDogeC5hcHByb3ZlcklkLFxyXG4gICAgICAgICAgICBzaGFyZWRLZXlJZDogeC5rZXlJZCxcclxuICAgICAgICAgICAgc2hhcmVkQ2lwaGVyRGF0YTogc2hhcmVkQ2lwaGVyRGF0YSB8fCAnJyxcclxuICAgICAgICAgICAgc2hhcmVkQ2lwaGVyQXBwcm92YWxEYXRhOiBzaGFyZWRDaXBoZXJBcHByb3ZhbERhdGEgfHwgJycsXHJcbiAgICAgICAgICAgIHNoYXJlZENpcGhlclBhcnRpYWxBc3NlbWJseUtleTogYXdhaXQgbmV4dFBhcnRpYWxBc3NlbWJseUtleShcclxuICAgICAgICAgICAgICBzaGFyZWRLZXkuandrXHJcbiAgICAgICAgICAgICksXHJcbiAgICAgICAgICB9O1xyXG4gICAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgICBjb25zdCB3cmFwcGVkQ29udGVudCA9IGF3YWl0IHRoaXMua2V5TWV0YVNlcnZpY2Uud3JhcENvbnRlbnRXaXRoS2V5KFxyXG4gICAgICAgICAgICB4LnBsYWluU2hhcmVkQ2lwaGVyRGF0YSxcclxuICAgICAgICAgICAgeC50cnVzdGVkUGFydHlTaGFyZWRLZXlJZFxyXG4gICAgICAgICAgKTtcclxuXHJcbiAgICAgICAgICByZXR1cm4ge1xyXG4gICAgICAgICAgICB0cElkOiB4LnRydXN0ZWRQYXJ0eUlkLFxyXG4gICAgICAgICAgICB0cFNoYXJlZEtleUlkOiB4LnRydXN0ZWRQYXJ0eVNoYXJlZEtleUlkLFxyXG4gICAgICAgICAgICB0cFNoYXJlZEtleVdyYXBwZWRTaGFyZWRLZXk6IHdyYXBwZWRDb250ZW50LnJvb3RLZXkud3JhcHBlZEtleSxcclxuICAgICAgICAgICAgc2hhcmVkQ2lwaGVyRGF0YTogd3JhcHBlZENvbnRlbnQuY2lwaGVyTWV0YSxcclxuICAgICAgICAgICAgc2hhcmVkQ2lwaGVyQXBwcm92YWxEYXRhOiAnJyxcclxuICAgICAgICAgICAgc2hhcmVkQ2lwaGVyUGFydGlhbEFzc2VtYmx5S2V5OiBhd2FpdCBuZXh0UGFydGlhbEFzc2VtYmx5S2V5KFxyXG4gICAgICAgICAgICAgIHdyYXBwZWRDb250ZW50LmtleVxyXG4gICAgICAgICAgICApLFxyXG4gICAgICAgICAgfTtcclxuICAgICAgICB9XHJcbiAgICAgIH0pXHJcbiAgICApO1xyXG4gIH1cclxuXHJcbiAgLy8gU3BsaXQgYXNzZW1ibHkga2V5IGJldHdlZW4gYWxsIGV4aXN0aW5nIGFwcHJvdmVycy5cclxuICBwcml2YXRlIGFzeW5jIGNyZWF0ZVNsaXBBc3NlbWJseShcclxuICAgIHF1b3J1bTogbnVtYmVyLFxyXG4gICAgYXBwcm92YWxHcm91cHM6IFVwZGF0ZVNjZW5hcmlvQXBwcm92YWxHcm91cFtdLFxyXG4gICAgcmF3QXNzZW1ibHlLZXk6IHN0cmluZ1xyXG4gICk6IFByb21pc2U8c2xpcC5Bc3NlbWJseT4ge1xyXG4gICAgY29uc3Qgc2xpcEFzc2VtYmx5ID0gbmV3IHNsaXAuQXNzZW1ibHkocXVvcnVtKTtcclxuXHJcbiAgICBhcHByb3ZhbEdyb3Vwcy5mb3JFYWNoKCh4LCBpbmRleCkgPT4ge1xyXG4gICAgICBsZXQgYXBwcm92ZXJDb3VudCA9IHguYXBwcm92ZXJzLmxlbmd0aDtcclxuXHJcbiAgICAgIC8vIHNsaXAzOSByZXN0cmljdHMgcXVvcnVtID09IDEgdG8gaGF2ZSBvbmx5IDEgbWVtYmVyLiBTbyB3ZSBqdXN0IHNoYXJlIHRoZSBzYW1lXHJcbiAgICAgIC8vIHBhcnRpYWwga2V5IGZvciBhbGwgc3ViIGFzc2VtYmx5IG1lbWJlcnMuXHJcbiAgICAgIGlmICh4LnF1b3J1bSA9PT0gMSkge1xyXG4gICAgICAgIGFwcHJvdmVyQ291bnQgPSAxO1xyXG4gICAgICB9XHJcbiAgICAgIHNsaXBBc3NlbWJseS5hZGRTdWJBc3NlbWJseShcclxuICAgICAgICBuZXcgc2xpcC5TdWJBc3NlbWJseShpbmRleCwgeC5xdW9ydW0sIGFwcHJvdmVyQ291bnQpXHJcbiAgICAgICk7XHJcbiAgICB9KTtcclxuICAgIC8vIElzIHRoZXJlIGVub3VnaCBzdWIgYXNzZW1ibGllcyB0byBtZWV0IHF1b3J1bVxyXG4gICAgaWYgKHNsaXBBc3NlbWJseS5zdWJBc3NlbWJsaWVzLmxlbmd0aCA8IHF1b3J1bSkge1xyXG4gICAgICByZXR1cm4gbnVsbDtcclxuICAgIH1cclxuICAgIGF3YWl0IHRoaXMuc2xpcDM5U2VydmljZS5nZW5lcmF0ZVNoYXJlcyhcclxuICAgICAgcmF3QXNzZW1ibHlLZXksXHJcbiAgICAgIFNjZW5hcmlvQXBwcm92ZXJTZXJ2aWNlLlNMSVAzOV9QQVNTUEhSQVNFLFxyXG4gICAgICBzbGlwQXNzZW1ibHlcclxuICAgICk7XHJcbiAgICByZXR1cm4gc2xpcEFzc2VtYmx5O1xyXG4gIH1cclxufVxyXG4iXX0=
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import gql from 'graphql-tag';
|
|
2
|
+
import { KeyGraphField } from '../../_common/queries.gql';
|
|
3
|
+
import { TrustedPartyProperties } from '../../trusted-parties/trusted-party.gql';
|
|
4
|
+
export const ClaimantFields = `
|
|
5
|
+
id
|
|
6
|
+
tp {
|
|
7
|
+
${TrustedPartyProperties}
|
|
8
|
+
}
|
|
9
|
+
sharedKey {
|
|
10
|
+
id
|
|
11
|
+
}
|
|
12
|
+
sharedCipherData
|
|
13
|
+
`;
|
|
14
|
+
export const GetScenarioClaimantQuery = gql `
|
|
15
|
+
query GetScenarioClaimantQuery(
|
|
16
|
+
$id: LrRelayIdInput!
|
|
17
|
+
) {
|
|
18
|
+
scenarioClaimant(id: $id) {
|
|
19
|
+
${ClaimantFields}
|
|
20
|
+
}
|
|
21
|
+
${KeyGraphField}
|
|
22
|
+
}`;
|
|
23
|
+
export const AddScenarioClaimantMutation = gql `
|
|
24
|
+
mutation AddScenarioClaimantMutation($input: AddScenarioClaimantInput!) {
|
|
25
|
+
addScenarioClaimant(input: $input) {
|
|
26
|
+
claimant {
|
|
27
|
+
id
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
`;
|
|
32
|
+
export const UpdateScenarioClaimantMutation = gql `
|
|
33
|
+
mutation UpdateScenarioClaimantMutation(
|
|
34
|
+
$input: UpdateScenarioClaimantInput!
|
|
35
|
+
) {
|
|
36
|
+
updateScenarioClaimant(input: $input) {
|
|
37
|
+
claimant {
|
|
38
|
+
id
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
`;
|
|
43
|
+
export const DeleteScenarioClaimantMutation = gql `
|
|
44
|
+
mutation DeleteScenarioClaimantMutation(
|
|
45
|
+
$input: DeleteScenarioClaimantInput!
|
|
46
|
+
) {
|
|
47
|
+
deleteScenarioClaimant(input: $input) {
|
|
48
|
+
id
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
`;
|
|
52
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NlbmFyaW8tY2xhaW1hbnQuZ3FsLmpzIiwic291cmNlUm9vdCI6IkM6L1Byb2plY3RzL25ld3JlcG8va2MtY2xpZW50L3Byb2plY3RzL2NvcmUvc3JjLyIsInNvdXJjZXMiOlsibGliL3NjZW5hcmlvL2NsYWltYW50cy9zY2VuYXJpby1jbGFpbWFudC5ncWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxHQUFHLE1BQU0sYUFBYSxDQUFDO0FBQzlCLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUVqRixNQUFNLENBQUMsTUFBTSxjQUFjLEdBQUc7OztJQUcxQixzQkFBc0I7Ozs7OztDQU16QixDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sd0JBQXdCLEdBQUcsR0FBRyxDQUFBOzs7OztNQUtyQyxjQUFjOztJQUVoQixhQUFhO0VBQ2YsQ0FBQztBQUVILE1BQU0sQ0FBQyxNQUFNLDJCQUEyQixHQUFHLEdBQUcsQ0FBQTs7Ozs7Ozs7Q0FRN0MsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLDhCQUE4QixHQUFHLEdBQUcsQ0FBQTs7Ozs7Ozs7OztDQVVoRCxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sOEJBQThCLEdBQUcsR0FBRyxDQUFBOzs7Ozs7OztDQVFoRCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGdxbCBmcm9tICdncmFwaHFsLXRhZyc7XHJcbmltcG9ydCB7IEtleUdyYXBoRmllbGQgfSBmcm9tICcuLi8uLi9fY29tbW9uL3F1ZXJpZXMuZ3FsJztcclxuaW1wb3J0IHsgVHJ1c3RlZFBhcnR5UHJvcGVydGllcyB9IGZyb20gJy4uLy4uL3RydXN0ZWQtcGFydGllcy90cnVzdGVkLXBhcnR5LmdxbCc7XHJcblxyXG5leHBvcnQgY29uc3QgQ2xhaW1hbnRGaWVsZHMgPSBgXHJcbmlkXHJcbnRwIHtcclxuICAke1RydXN0ZWRQYXJ0eVByb3BlcnRpZXN9XHJcbn1cclxuc2hhcmVkS2V5IHtcclxuICBpZFxyXG59XHJcbnNoYXJlZENpcGhlckRhdGFcclxuYDtcclxuXHJcbmV4cG9ydCBjb25zdCBHZXRTY2VuYXJpb0NsYWltYW50UXVlcnkgPSBncWxgXHJcbnF1ZXJ5IEdldFNjZW5hcmlvQ2xhaW1hbnRRdWVyeShcclxuICAkaWQ6IExyUmVsYXlJZElucHV0IVxyXG4pIHtcclxuICBzY2VuYXJpb0NsYWltYW50KGlkOiAkaWQpIHtcclxuICAgICR7Q2xhaW1hbnRGaWVsZHN9XHJcbiAgfVxyXG4gICR7S2V5R3JhcGhGaWVsZH1cclxufWA7XHJcblxyXG5leHBvcnQgY29uc3QgQWRkU2NlbmFyaW9DbGFpbWFudE11dGF0aW9uID0gZ3FsYFxyXG4gIG11dGF0aW9uIEFkZFNjZW5hcmlvQ2xhaW1hbnRNdXRhdGlvbigkaW5wdXQ6IEFkZFNjZW5hcmlvQ2xhaW1hbnRJbnB1dCEpIHtcclxuICAgIGFkZFNjZW5hcmlvQ2xhaW1hbnQoaW5wdXQ6ICRpbnB1dCkge1xyXG4gICAgICBjbGFpbWFudCB7XHJcbiAgICAgICAgaWRcclxuICAgICAgfVxyXG4gICAgfVxyXG4gIH1cclxuYDtcclxuXHJcbmV4cG9ydCBjb25zdCBVcGRhdGVTY2VuYXJpb0NsYWltYW50TXV0YXRpb24gPSBncWxgXHJcbiAgbXV0YXRpb24gVXBkYXRlU2NlbmFyaW9DbGFpbWFudE11dGF0aW9uKFxyXG4gICAgJGlucHV0OiBVcGRhdGVTY2VuYXJpb0NsYWltYW50SW5wdXQhXHJcbiAgKSB7XHJcbiAgICB1cGRhdGVTY2VuYXJpb0NsYWltYW50KGlucHV0OiAkaW5wdXQpIHtcclxuICAgICAgY2xhaW1hbnQge1xyXG4gICAgICAgIGlkXHJcbiAgICAgIH1cclxuICAgIH1cclxuICB9XHJcbmA7XHJcblxyXG5leHBvcnQgY29uc3QgRGVsZXRlU2NlbmFyaW9DbGFpbWFudE11dGF0aW9uID0gZ3FsYFxyXG4gIG11dGF0aW9uIERlbGV0ZVNjZW5hcmlvQ2xhaW1hbnRNdXRhdGlvbihcclxuICAgICRpbnB1dDogRGVsZXRlU2NlbmFyaW9DbGFpbWFudElucHV0IVxyXG4gICkge1xyXG4gICAgZGVsZXRlU2NlbmFyaW9DbGFpbWFudChpbnB1dDogJGlucHV0KSB7XHJcbiAgICAgIGlkXHJcbiAgICB9XHJcbiAgfVxyXG5gO1xyXG4iXX0=
|
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
2
|
+
import { Injectable } from '@angular/core';
|
|
3
|
+
import { LrApolloService } from '../../api/lr-apollo.service';
|
|
4
|
+
import { KeyGraphService } from '../../cryptography/key-graph.service';
|
|
5
|
+
import { KeyMetaService } from '../../cryptography/key-meta.service';
|
|
6
|
+
import { TrustedPartyService } from '../../trusted-parties/trusted-party.service';
|
|
7
|
+
import { DeleteScenarioClaimantMutation, UpdateScenarioClaimantMutation, GetScenarioClaimantQuery, AddScenarioClaimantMutation, } from './scenario-claimant.gql';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "../../api/lr-apollo.service";
|
|
10
|
+
import * as i2 from "../../cryptography/key-meta.service";
|
|
11
|
+
import * as i3 from "../../cryptography/key-graph.service";
|
|
12
|
+
import * as i4 from "../../trusted-parties/trusted-party.service";
|
|
13
|
+
export class ScenarioClaimantService {
|
|
14
|
+
constructor(lrApollo, keyMetaService, keyGraph, tpService) {
|
|
15
|
+
this.lrApollo = lrApollo;
|
|
16
|
+
this.keyMetaService = keyMetaService;
|
|
17
|
+
this.keyGraph = keyGraph;
|
|
18
|
+
this.tpService = tpService;
|
|
19
|
+
}
|
|
20
|
+
getClaimant(claimantId) {
|
|
21
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
22
|
+
const { scenarioClaimant } = yield this.lrApollo.query({
|
|
23
|
+
query: GetScenarioClaimantQuery,
|
|
24
|
+
variables: {
|
|
25
|
+
id: claimantId,
|
|
26
|
+
},
|
|
27
|
+
});
|
|
28
|
+
return this.mapClaimant(scenarioClaimant);
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
mapClaimant(claimant) {
|
|
32
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
33
|
+
const { message } = yield this.keyGraph.decryptFromString(claimant.sharedKey.id, claimant.sharedCipherData);
|
|
34
|
+
return {
|
|
35
|
+
id: claimant.id,
|
|
36
|
+
keyId: claimant.sharedKey.id,
|
|
37
|
+
trustedParty: yield this.tpService.mapTrustedParty(claimant.tp),
|
|
38
|
+
message,
|
|
39
|
+
};
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
addClaimant(claimant) {
|
|
43
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
44
|
+
const wrappedContent = yield this.keyMetaService.wrapContentWithKey(claimant.plainSharedCipherData, claimant.trustedPartySharedKeyId);
|
|
45
|
+
const { addScenarioClaimant } = yield this.lrApollo.mutate({
|
|
46
|
+
mutation: AddScenarioClaimantMutation,
|
|
47
|
+
variables: {
|
|
48
|
+
input: {
|
|
49
|
+
scenarioId: claimant.scenarioId,
|
|
50
|
+
tpId: claimant.trustedPartyId,
|
|
51
|
+
tpSharedKeyId: claimant.trustedPartySharedKeyId,
|
|
52
|
+
tpSharedKeyWrappedSharedKey: wrappedContent.rootKey.wrappedKey,
|
|
53
|
+
sharedCipherData: wrappedContent.cipherMeta,
|
|
54
|
+
},
|
|
55
|
+
},
|
|
56
|
+
});
|
|
57
|
+
return addScenarioClaimant.claimant.id;
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
updateClaimant(claimant) {
|
|
61
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
62
|
+
const sharedCipherData = yield this.keyGraph.encryptToString(claimant.keyId, claimant.plainSharedCipherData);
|
|
63
|
+
const res = yield this.lrApollo.mutate({
|
|
64
|
+
mutation: UpdateScenarioClaimantMutation,
|
|
65
|
+
variables: {
|
|
66
|
+
input: {
|
|
67
|
+
claimantId: claimant.id,
|
|
68
|
+
sharedKeyId: claimant.keyId,
|
|
69
|
+
sharedCipherData,
|
|
70
|
+
},
|
|
71
|
+
},
|
|
72
|
+
});
|
|
73
|
+
return res.updateScenarioClaimant.claimant.id;
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
deleteClaimant(claimantId) {
|
|
77
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
78
|
+
yield this.lrApollo.mutate({
|
|
79
|
+
mutation: DeleteScenarioClaimantMutation,
|
|
80
|
+
variables: { input: { claimantId } },
|
|
81
|
+
});
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
ScenarioClaimantService.ɵprov = i0.ɵɵdefineInjectable({ factory: function ScenarioClaimantService_Factory() { return new ScenarioClaimantService(i0.ɵɵinject(i1.LrApolloService), i0.ɵɵinject(i2.KeyMetaService), i0.ɵɵinject(i3.KeyGraphService), i0.ɵɵinject(i4.TrustedPartyService)); }, token: ScenarioClaimantService, providedIn: "root" });
|
|
86
|
+
ScenarioClaimantService.decorators = [
|
|
87
|
+
{ type: Injectable, args: [{
|
|
88
|
+
providedIn: 'root',
|
|
89
|
+
},] }
|
|
90
|
+
];
|
|
91
|
+
ScenarioClaimantService.ctorParameters = () => [
|
|
92
|
+
{ type: LrApolloService },
|
|
93
|
+
{ type: KeyMetaService },
|
|
94
|
+
{ type: KeyGraphService },
|
|
95
|
+
{ type: TrustedPartyService }
|
|
96
|
+
];
|
|
97
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NlbmFyaW8tY2xhaW1hbnQuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiJDOi9Qcm9qZWN0cy9uZXdyZXBvL2tjLWNsaWVudC9wcm9qZWN0cy9jb3JlL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9zY2VuYXJpby9jbGFpbWFudHMvc2NlbmFyaW8tY2xhaW1hbnQuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDOUQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUNyRSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSw2Q0FBNkMsQ0FBQztBQUNsRixPQUFPLEVBQ0wsOEJBQThCLEVBQzlCLDhCQUE4QixFQUM5Qix3QkFBd0IsRUFDeEIsMkJBQTJCLEdBQzVCLE1BQU0seUJBQXlCLENBQUM7Ozs7OztBQVVqQyxNQUFNLE9BQU8sdUJBQXVCO0lBQ2xDLFlBQ1UsUUFBeUIsRUFDekIsY0FBOEIsRUFDOUIsUUFBeUIsRUFDekIsU0FBOEI7UUFIOUIsYUFBUSxHQUFSLFFBQVEsQ0FBaUI7UUFDekIsbUJBQWMsR0FBZCxjQUFjLENBQWdCO1FBQzlCLGFBQVEsR0FBUixRQUFRLENBQWlCO1FBQ3pCLGNBQVMsR0FBVCxTQUFTLENBQXFCO0lBQ3JDLENBQUM7SUFFUyxXQUFXLENBQUMsVUFBa0I7O1lBQ3pDLE1BQU0sRUFBRSxnQkFBZ0IsRUFBRSxHQUFHLE1BQU0sSUFBSSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQU07Z0JBQzFELEtBQUssRUFBRSx3QkFBd0I7Z0JBQy9CLFNBQVMsRUFBRTtvQkFDVCxFQUFFLEVBQUUsVUFBVTtpQkFDZjthQUNGLENBQUMsQ0FBQztZQUNILE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1FBQzVDLENBQUM7S0FBQTtJQUVZLFdBQVcsQ0FBQyxRQUFhOztZQUNwQyxNQUFNLEVBQUUsT0FBTyxFQUFFLEdBQUcsTUFBTSxJQUFJLENBQUMsUUFBUSxDQUFDLGlCQUFpQixDQUV0RCxRQUFRLENBQUMsU0FBUyxDQUFDLEVBQUUsRUFBRSxRQUFRLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztZQUVyRCxPQUFPO2dCQUNMLEVBQUUsRUFBRSxRQUFRLENBQUMsRUFBRTtnQkFDZixLQUFLLEVBQUUsUUFBUSxDQUFDLFNBQVMsQ0FBQyxFQUFFO2dCQUM1QixZQUFZLEVBQUUsTUFBTSxJQUFJLENBQUMsU0FBUyxDQUFDLGVBQWUsQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDO2dCQUMvRCxPQUFPO2FBQ1IsQ0FBQztRQUNKLENBQUM7S0FBQTtJQUVZLFdBQVcsQ0FBQyxRQUE2Qjs7WUFDcEQsTUFBTSxjQUFjLEdBQUcsTUFBTSxJQUFJLENBQUMsY0FBYyxDQUFDLGtCQUFrQixDQUNqRSxRQUFRLENBQUMscUJBQXFCLEVBQzlCLFFBQVEsQ0FBQyx1QkFBdUIsQ0FDakMsQ0FBQztZQUVGLE1BQU0sRUFBRSxtQkFBbUIsRUFBRSxHQUFHLE1BQU0sSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQU07Z0JBQzlELFFBQVEsRUFBRSwyQkFBMkI7Z0JBQ3JDLFNBQVMsRUFBRTtvQkFDVCxLQUFLLEVBQUU7d0JBQ0wsVUFBVSxFQUFFLFFBQVEsQ0FBQyxVQUFVO3dCQUMvQixJQUFJLEVBQUUsUUFBUSxDQUFDLGNBQWM7d0JBQzdCLGFBQWEsRUFBRSxRQUFRLENBQUMsdUJBQXVCO3dCQUMvQywyQkFBMkIsRUFBRSxjQUFjLENBQUMsT0FBTyxDQUFDLFVBQVU7d0JBQzlELGdCQUFnQixFQUFFLGNBQWMsQ0FBQyxVQUFVO3FCQUM1QztpQkFDRjthQUNGLENBQUMsQ0FBQztZQUNILE9BQU8sbUJBQW1CLENBQUMsUUFBUSxDQUFDLEVBQUUsQ0FBQztRQUN6QyxDQUFDO0tBQUE7SUFFWSxjQUFjLENBQ3pCLFFBQWdDOztZQUVoQyxNQUFNLGdCQUFnQixHQUFHLE1BQU0sSUFBSSxDQUFDLFFBQVEsQ0FBQyxlQUFlLENBQzFELFFBQVEsQ0FBQyxLQUFLLEVBQ2QsUUFBUSxDQUFDLHFCQUFxQixDQUMvQixDQUFDO1lBRUYsTUFBTSxHQUFHLEdBQUcsTUFBTSxJQUFJLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBTTtnQkFDMUMsUUFBUSxFQUFFLDhCQUE4QjtnQkFDeEMsU0FBUyxFQUFFO29CQUNULEtBQUssRUFBRTt3QkFDTCxVQUFVLEVBQUUsUUFBUSxDQUFDLEVBQUU7d0JBQ3ZCLFdBQVcsRUFBRSxRQUFRLENBQUMsS0FBSzt3QkFDM0IsZ0JBQWdCO3FCQUNqQjtpQkFDRjthQUNGLENBQUMsQ0FBQztZQUNILE9BQU8sR0FBRyxDQUFDLHNCQUFzQixDQUFDLFFBQVEsQ0FBQyxFQUFFLENBQUM7UUFDaEQsQ0FBQztLQUFBO0lBRVksY0FBYyxDQUFDLFVBQWtCOztZQUM1QyxNQUFNLElBQUksQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFNO2dCQUM5QixRQUFRLEVBQUUsOEJBQThCO2dCQUN4QyxTQUFTLEVBQUUsRUFBRSxLQUFLLEVBQUUsRUFBRSxVQUFVLEVBQUUsRUFBRTthQUNyQyxDQUFDLENBQUM7UUFDTCxDQUFDO0tBQUE7Ozs7WUFqRkYsVUFBVSxTQUFDO2dCQUNWLFVBQVUsRUFBRSxNQUFNO2FBQ25COzs7WUFsQlEsZUFBZTtZQUVmLGNBQWM7WUFEZCxlQUFlO1lBRWYsbUJBQW1CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBMckFwb2xsb1NlcnZpY2UgfSBmcm9tICcuLi8uLi9hcGkvbHItYXBvbGxvLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBLZXlHcmFwaFNlcnZpY2UgfSBmcm9tICcuLi8uLi9jcnlwdG9ncmFwaHkva2V5LWdyYXBoLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBLZXlNZXRhU2VydmljZSB9IGZyb20gJy4uLy4uL2NyeXB0b2dyYXBoeS9rZXktbWV0YS5zZXJ2aWNlJztcclxuaW1wb3J0IHsgVHJ1c3RlZFBhcnR5U2VydmljZSB9IGZyb20gJy4uLy4uL3RydXN0ZWQtcGFydGllcy90cnVzdGVkLXBhcnR5LnNlcnZpY2UnO1xyXG5pbXBvcnQge1xyXG4gIERlbGV0ZVNjZW5hcmlvQ2xhaW1hbnRNdXRhdGlvbixcclxuICBVcGRhdGVTY2VuYXJpb0NsYWltYW50TXV0YXRpb24sXHJcbiAgR2V0U2NlbmFyaW9DbGFpbWFudFF1ZXJ5LFxyXG4gIEFkZFNjZW5hcmlvQ2xhaW1hbnRNdXRhdGlvbixcclxufSBmcm9tICcuL3NjZW5hcmlvLWNsYWltYW50LmdxbCc7XHJcbmltcG9ydCB7XHJcbiAgQ2xhaW1hbnQsXHJcbiAgQWRkU2NlbmFyaW9DbGFpbWFudCxcclxuICBVcGRhdGVTY2VuYXJpb0NsYWltYW50LFxyXG59IGZyb20gJy4vc2NlbmFyaW8tY2xhaW1hbnQudHlwZXMnO1xyXG5cclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46ICdyb290JyxcclxufSlcclxuZXhwb3J0IGNsYXNzIFNjZW5hcmlvQ2xhaW1hbnRTZXJ2aWNlIHtcclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByaXZhdGUgbHJBcG9sbG86IExyQXBvbGxvU2VydmljZSxcclxuICAgIHByaXZhdGUga2V5TWV0YVNlcnZpY2U6IEtleU1ldGFTZXJ2aWNlLFxyXG4gICAgcHJpdmF0ZSBrZXlHcmFwaDogS2V5R3JhcGhTZXJ2aWNlLFxyXG4gICAgcHJpdmF0ZSB0cFNlcnZpY2U6IFRydXN0ZWRQYXJ0eVNlcnZpY2VcclxuICApIHt9XHJcblxyXG4gIHB1YmxpYyBhc3luYyBnZXRDbGFpbWFudChjbGFpbWFudElkOiBzdHJpbmcpOiBQcm9taXNlPENsYWltYW50PiB7XHJcbiAgICBjb25zdCB7IHNjZW5hcmlvQ2xhaW1hbnQgfSA9IGF3YWl0IHRoaXMubHJBcG9sbG8ucXVlcnk8YW55Pih7XHJcbiAgICAgIHF1ZXJ5OiBHZXRTY2VuYXJpb0NsYWltYW50UXVlcnksXHJcbiAgICAgIHZhcmlhYmxlczoge1xyXG4gICAgICAgIGlkOiBjbGFpbWFudElkLFxyXG4gICAgICB9LFxyXG4gICAgfSk7XHJcbiAgICByZXR1cm4gdGhpcy5tYXBDbGFpbWFudChzY2VuYXJpb0NsYWltYW50KTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBhc3luYyBtYXBDbGFpbWFudChjbGFpbWFudDogYW55KTogUHJvbWlzZTxDbGFpbWFudD4ge1xyXG4gICAgY29uc3QgeyBtZXNzYWdlIH0gPSBhd2FpdCB0aGlzLmtleUdyYXBoLmRlY3J5cHRGcm9tU3RyaW5nPHtcclxuICAgICAgbWVzc2FnZTogc3RyaW5nO1xyXG4gICAgfT4oY2xhaW1hbnQuc2hhcmVkS2V5LmlkLCBjbGFpbWFudC5zaGFyZWRDaXBoZXJEYXRhKTtcclxuXHJcbiAgICByZXR1cm4ge1xyXG4gICAgICBpZDogY2xhaW1hbnQuaWQsXHJcbiAgICAgIGtleUlkOiBjbGFpbWFudC5zaGFyZWRLZXkuaWQsXHJcbiAgICAgIHRydXN0ZWRQYXJ0eTogYXdhaXQgdGhpcy50cFNlcnZpY2UubWFwVHJ1c3RlZFBhcnR5KGNsYWltYW50LnRwKSxcclxuICAgICAgbWVzc2FnZSxcclxuICAgIH07XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgYXN5bmMgYWRkQ2xhaW1hbnQoY2xhaW1hbnQ6IEFkZFNjZW5hcmlvQ2xhaW1hbnQpOiBQcm9taXNlPHN0cmluZz4ge1xyXG4gICAgY29uc3Qgd3JhcHBlZENvbnRlbnQgPSBhd2FpdCB0aGlzLmtleU1ldGFTZXJ2aWNlLndyYXBDb250ZW50V2l0aEtleShcclxuICAgICAgY2xhaW1hbnQucGxhaW5TaGFyZWRDaXBoZXJEYXRhLFxyXG4gICAgICBjbGFpbWFudC50cnVzdGVkUGFydHlTaGFyZWRLZXlJZFxyXG4gICAgKTtcclxuXHJcbiAgICBjb25zdCB7IGFkZFNjZW5hcmlvQ2xhaW1hbnQgfSA9IGF3YWl0IHRoaXMubHJBcG9sbG8ubXV0YXRlPGFueT4oe1xyXG4gICAgICBtdXRhdGlvbjogQWRkU2NlbmFyaW9DbGFpbWFudE11dGF0aW9uLFxyXG4gICAgICB2YXJpYWJsZXM6IHtcclxuICAgICAgICBpbnB1dDoge1xyXG4gICAgICAgICAgc2NlbmFyaW9JZDogY2xhaW1hbnQuc2NlbmFyaW9JZCxcclxuICAgICAgICAgIHRwSWQ6IGNsYWltYW50LnRydXN0ZWRQYXJ0eUlkLFxyXG4gICAgICAgICAgdHBTaGFyZWRLZXlJZDogY2xhaW1hbnQudHJ1c3RlZFBhcnR5U2hhcmVkS2V5SWQsXHJcbiAgICAgICAgICB0cFNoYXJlZEtleVdyYXBwZWRTaGFyZWRLZXk6IHdyYXBwZWRDb250ZW50LnJvb3RLZXkud3JhcHBlZEtleSxcclxuICAgICAgICAgIHNoYXJlZENpcGhlckRhdGE6IHdyYXBwZWRDb250ZW50LmNpcGhlck1ldGEsXHJcbiAgICAgICAgfSxcclxuICAgICAgfSxcclxuICAgIH0pO1xyXG4gICAgcmV0dXJuIGFkZFNjZW5hcmlvQ2xhaW1hbnQuY2xhaW1hbnQuaWQ7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgYXN5bmMgdXBkYXRlQ2xhaW1hbnQoXHJcbiAgICBjbGFpbWFudDogVXBkYXRlU2NlbmFyaW9DbGFpbWFudFxyXG4gICk6IFByb21pc2U8c3RyaW5nPiB7XHJcbiAgICBjb25zdCBzaGFyZWRDaXBoZXJEYXRhID0gYXdhaXQgdGhpcy5rZXlHcmFwaC5lbmNyeXB0VG9TdHJpbmcoXHJcbiAgICAgIGNsYWltYW50LmtleUlkLFxyXG4gICAgICBjbGFpbWFudC5wbGFpblNoYXJlZENpcGhlckRhdGFcclxuICAgICk7XHJcblxyXG4gICAgY29uc3QgcmVzID0gYXdhaXQgdGhpcy5sckFwb2xsby5tdXRhdGU8YW55Pih7XHJcbiAgICAgIG11dGF0aW9uOiBVcGRhdGVTY2VuYXJpb0NsYWltYW50TXV0YXRpb24sXHJcbiAgICAgIHZhcmlhYmxlczoge1xyXG4gICAgICAgIGlucHV0OiB7XHJcbiAgICAgICAgICBjbGFpbWFudElkOiBjbGFpbWFudC5pZCxcclxuICAgICAgICAgIHNoYXJlZEtleUlkOiBjbGFpbWFudC5rZXlJZCxcclxuICAgICAgICAgIHNoYXJlZENpcGhlckRhdGEsXHJcbiAgICAgICAgfSxcclxuICAgICAgfSxcclxuICAgIH0pO1xyXG4gICAgcmV0dXJuIHJlcy51cGRhdGVTY2VuYXJpb0NsYWltYW50LmNsYWltYW50LmlkO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGFzeW5jIGRlbGV0ZUNsYWltYW50KGNsYWltYW50SWQ6IHN0cmluZyk6IFByb21pc2U8dm9pZD4ge1xyXG4gICAgYXdhaXQgdGhpcy5sckFwb2xsby5tdXRhdGU8YW55Pih7XHJcbiAgICAgIG11dGF0aW9uOiBEZWxldGVTY2VuYXJpb0NsYWltYW50TXV0YXRpb24sXHJcbiAgICAgIHZhcmlhYmxlczogeyBpbnB1dDogeyBjbGFpbWFudElkIH0gfSxcclxuICAgIH0pO1xyXG4gIH1cclxufVxyXG4iXX0=
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NlbmFyaW8tY2xhaW1hbnQudHlwZXMuanMiLCJzb3VyY2VSb290IjoiQzovUHJvamVjdHMvbmV3cmVwby9rYy1jbGllbnQvcHJvamVjdHMvY29yZS9zcmMvIiwic291cmNlcyI6WyJsaWIvc2NlbmFyaW8vY2xhaW1hbnRzL3NjZW5hcmlvLWNsYWltYW50LnR5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUcnVzdGVkUGFydHkgfSBmcm9tICcuLi8uLi90cnVzdGVkLXBhcnRpZXMvdHJ1c3RlZC1wYXJ0eS50eXBlcyc7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIENsYWltYW50IHtcclxuICBpZDogc3RyaW5nO1xyXG4gIGtleUlkOiBzdHJpbmc7XHJcbiAgdHJ1c3RlZFBhcnR5OiBUcnVzdGVkUGFydHk7XHJcbiAgbWVzc2FnZT86IHN0cmluZztcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBBZGRTY2VuYXJpb0NsYWltYW50IHtcclxuICBzY2VuYXJpb0lkOiBzdHJpbmc7XHJcbiAgdHJ1c3RlZFBhcnR5SWQ6IHN0cmluZztcclxuICB0cnVzdGVkUGFydHlTaGFyZWRLZXlJZDogc3RyaW5nO1xyXG4gIHBsYWluU2hhcmVkQ2lwaGVyRGF0YTogb2JqZWN0O1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIFVwZGF0ZVNjZW5hcmlvQ2xhaW1hbnQge1xyXG4gIGlkOiBzdHJpbmc7XHJcbiAga2V5SWQ6IHN0cmluZztcclxuICBwbGFpblNoYXJlZENpcGhlckRhdGE6IG9iamVjdDtcclxufVxyXG4iXX0=
|