@lifeready/core 1.0.0 → 1.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +62 -62
- package/karma.conf.js +32 -0
- package/ng-package.json +26 -0
- package/package.json +21 -29
- package/src/lib/_common/ast.ts +75 -0
- package/src/lib/_common/deferred-promise.ts +35 -0
- package/src/lib/_common/exceptions.ts +189 -0
- package/src/lib/_common/queries.gql.ts +200 -0
- package/src/lib/_common/run-outside-angular.ts +125 -0
- package/src/lib/_common/tests.ts +82 -0
- package/{lib/_common/types.d.ts → src/lib/_common/types.ts} +13 -10
- package/src/lib/_common/utils.ts +57 -0
- package/src/lib/api/api-mutation.spec.ts +547 -0
- package/src/lib/api/api-query.spec.ts +40 -0
- package/src/lib/api/contact-card.gql.ts +85 -0
- package/src/lib/api/contact-card.service.spec.ts +249 -0
- package/src/lib/api/contact-card.service.ts +228 -0
- package/src/lib/api/contact-card2.gql.ts +93 -0
- package/src/lib/api/contact-card2.service.spec.ts +297 -0
- package/src/lib/api/contact-card2.service.ts +139 -0
- package/src/lib/api/file.service.spec.ts +14 -0
- package/src/lib/api/file.service.ts +81 -0
- package/src/lib/api/item2.gql.ts +211 -0
- package/src/lib/api/item2.service.spec.ts +1043 -0
- package/src/lib/api/item2.service.ts +481 -0
- package/src/lib/api/key-exchange.gql.ts +196 -0
- package/src/lib/api/key-exchange.service.spec.ts +470 -0
- package/src/lib/api/key-exchange.service.ts +731 -0
- package/src/lib/api/key-exchange.types.ts +235 -0
- package/src/lib/api/key-exchange2.gql.ts +310 -0
- package/src/lib/api/key-exchange2.service.spec.ts +892 -0
- package/src/lib/api/key-exchange2.service.ts +875 -0
- package/src/lib/api/lock.gql.ts +67 -0
- package/src/lib/api/lock.service.spec.ts +549 -0
- package/src/lib/api/lock.service.ts +57 -0
- package/src/lib/api/lr-apollo.service.spec.ts +27 -0
- package/src/lib/api/lr-apollo.service.ts +43 -0
- package/{lib/api/lr-graphql/index.d.ts → src/lib/api/lr-graphql/index.ts} +5 -5
- package/src/lib/api/lr-graphql/lr-graphql.service.ts +313 -0
- package/src/lib/api/lr-graphql/lr-merged-mutation.ts +377 -0
- package/src/lib/api/lr-graphql/lr-mutation-base.ts +67 -0
- package/src/lib/api/lr-graphql/lr-mutation.ts +74 -0
- package/src/lib/api/lr-graphql/lr.service.ts +28 -0
- package/src/lib/api/message.service.spec.ts +20 -0
- package/src/lib/api/message.service.ts +210 -0
- package/src/lib/api/persist.service.spec.ts +209 -0
- package/src/lib/api/persist.service.ts +220 -0
- package/src/lib/api/query-processor/common-processors.service.ts +148 -0
- package/{lib/api/query-processor/index.d.ts → src/lib/api/query-processor/index.ts} +2 -2
- package/src/lib/api/query-processor/query-processor.service.ts +240 -0
- package/src/lib/api/query-processor/tp-password-reset-processor.service.ts +177 -0
- package/src/lib/api/shared-contact-card.service.ts +156 -0
- package/src/lib/api/shared-contact-card2.gql.ts +76 -0
- package/src/lib/api/shared-contact-card2.service.ts +154 -0
- package/src/lib/api/time.service.spec.ts +48 -0
- package/src/lib/api/time.service.ts +155 -0
- package/src/lib/api/types/graphql.types.ts +48 -0
- package/{lib/api/types/index.d.ts → src/lib/api/types/index.ts} +2 -2
- package/src/lib/api/types/lr-graphql.types.ts +467 -0
- package/src/lib/auth/auth.config.ts +83 -0
- package/src/lib/auth/auth.gql.ts +62 -0
- package/src/lib/auth/auth.types.ts +79 -0
- package/src/lib/auth/idle.service.spec.ts +119 -0
- package/src/lib/auth/idle.service.ts +208 -0
- package/src/lib/auth/idle.types.ts +11 -0
- package/src/lib/auth/lbop.service.spec.ts +56 -0
- package/src/lib/auth/lbop.service.ts +539 -0
- package/src/lib/auth/life-ready-auth.service.spec.ts +70 -0
- package/src/lib/auth/life-ready-auth.service.ts +454 -0
- package/src/lib/auth/password.service.spec.ts +51 -0
- package/src/lib/auth/password.service.ts +438 -0
- package/src/lib/auth/register.service.spec.ts +31 -0
- package/src/lib/auth/register.service.ts +181 -0
- package/src/lib/auth/two-factor.service.spec.ts +21 -0
- package/src/lib/auth/two-factor.service.ts +69 -0
- package/src/lib/category/category-meta.service.spec.ts +28 -0
- package/src/lib/category/category-meta.service.ts +125 -0
- package/src/lib/category/category.gql.ts +449 -0
- package/src/lib/category/category.service.spec.ts +26 -0
- package/src/lib/category/category.service.ts +498 -0
- package/src/lib/category/category.types.ts +89 -0
- package/src/lib/cryptography/cryptography.types.ts +108 -0
- package/src/lib/cryptography/encryption.service.spec.ts +125 -0
- package/src/lib/cryptography/encryption.service.ts +243 -0
- package/src/lib/cryptography/key-factory.service.spec.ts +15 -0
- package/src/lib/cryptography/key-factory.service.ts +303 -0
- package/src/lib/cryptography/key-graph.service.spec.ts +16 -0
- package/src/lib/cryptography/key-graph.service.ts +354 -0
- package/src/lib/cryptography/key-meta.service.spec.ts +40 -0
- package/src/lib/cryptography/key-meta.service.ts +254 -0
- package/src/lib/cryptography/key.service.spec.ts +16 -0
- package/src/lib/cryptography/key.service.ts +154 -0
- package/src/lib/cryptography/slip39.service.spec.ts +44 -0
- package/src/lib/cryptography/slip39.service.ts +204 -0
- package/src/lib/cryptography/web-crypto.service.ts +22 -0
- package/src/lib/life-ready.config.ts +127 -0
- package/src/lib/life-ready.module.ts +81 -0
- package/src/lib/plan/plan.gql.ts +133 -0
- package/src/lib/plan/plan.service.spec.ts +294 -0
- package/src/lib/plan/plan.service.ts +198 -0
- package/src/lib/plan/plan.types.ts +37 -0
- package/src/lib/record/record-attachment.service.spec.ts +31 -0
- package/src/lib/record/record-attachment.service.ts +101 -0
- package/src/lib/record/record.gql.ts +192 -0
- package/src/lib/record/record.service.spec.ts +598 -0
- package/src/lib/record/record.service.ts +236 -0
- package/src/lib/record/record.types.ts +86 -0
- package/src/lib/record-type/record-type.service.spec.ts +16 -0
- package/src/lib/record-type/record-type.service.ts +71 -0
- package/src/lib/record-type/record-type.types.ts +58 -0
- package/src/lib/scenario/approvals/scenario-approval.gql.ts +112 -0
- package/src/lib/scenario/approvals/scenario-approval.types.ts +85 -0
- package/src/lib/scenario/approvals/scenario-approver.service.spec.ts +16 -0
- package/src/lib/scenario/approvals/scenario-approver.service.ts +422 -0
- package/src/lib/scenario/claimants/scenario-claimant.gql.ts +56 -0
- package/src/lib/scenario/claimants/scenario-claimant.service.spec.ts +16 -0
- package/src/lib/scenario/claimants/scenario-claimant.service.ts +100 -0
- package/src/lib/scenario/claimants/scenario-claimant.types.ts +21 -0
- package/src/lib/scenario/receivers/scenario-receiver.gql.ts +157 -0
- package/src/lib/scenario/receivers/scenario-receiver.service.spec.ts +16 -0
- package/src/lib/scenario/receivers/scenario-receiver.service.ts +278 -0
- package/src/lib/scenario/receivers/scenario-receiver.types.ts +66 -0
- package/src/lib/scenario/scenario-setup.service.spec.ts +22 -0
- package/src/lib/scenario/scenario-setup.service.ts +369 -0
- package/src/lib/scenario/scenario.gql.ts +404 -0
- package/src/lib/scenario/scenario.service.spec.ts +1586 -0
- package/src/lib/scenario/scenario.service.ts +811 -0
- package/src/lib/scenario/scenario.types.ts +258 -0
- package/src/lib/search/search.gql.ts +62 -0
- package/src/lib/search/search.service.spec.ts +57 -0
- package/src/lib/search/search.service.ts +174 -0
- package/src/lib/search/search.types.ts +24 -0
- package/src/lib/trusted-parties/tp-password-reset-request.service.ts +140 -0
- package/src/lib/trusted-parties/tp-password-reset-user.service.ts +359 -0
- package/src/lib/trusted-parties/tp-password-reset.gql.ts +453 -0
- package/src/lib/trusted-parties/tp-password-reset.service.spec.ts +602 -0
- package/src/lib/trusted-parties/tp-password-reset.service.ts +482 -0
- package/src/lib/trusted-parties/trusted-party.gql.ts +159 -0
- package/src/lib/trusted-parties/trusted-party.service.spec.ts +1008 -0
- package/src/lib/trusted-parties/trusted-party.service.ts +394 -0
- package/src/lib/trusted-parties/trusted-party.types.ts +119 -0
- package/src/lib/trusted-parties/trusted-party2.gql.ts +165 -0
- package/src/lib/trusted-parties/trusted-party2.service.spec.ts +1782 -0
- package/src/lib/trusted-parties/trusted-party2.service.ts +272 -0
- package/src/lib/users/profile-details.service.spec.ts +45 -0
- package/src/lib/users/profile-details.service.ts +278 -0
- package/src/lib/users/profile.gql.ts +108 -0
- package/src/lib/users/profile.service.spec.ts +97 -0
- package/src/lib/users/profile.service.ts +224 -0
- package/src/lib/users/profile.types.ts +101 -0
- package/src/lib/users/user.gql.ts +69 -0
- package/src/lib/users/user.service.spec.ts +161 -0
- package/src/lib/users/user.service.ts +72 -0
- package/src/lib/users/user.types.ts +27 -0
- package/{public-api.d.ts → src/public-api.ts} +96 -77
- package/src/test.ts +21 -0
- package/tsconfig.lib.json +21 -0
- package/tsconfig.lib.prod.json +6 -0
- package/tsconfig.spec.json +10 -0
- package/tslint.json +17 -0
- package/bundles/lifeready-core.umd.js +0 -15876
- package/bundles/lifeready-core.umd.js.map +0 -1
- package/bundles/lifeready-core.umd.min.js +0 -16
- package/bundles/lifeready-core.umd.min.js.map +0 -1
- package/esm2015/lib/_common/ast.js +0 -40
- package/esm2015/lib/_common/deferred-promise.js +0 -24
- package/esm2015/lib/_common/exceptions.js +0 -157
- package/esm2015/lib/_common/queries.gql.js +0 -190
- package/esm2015/lib/_common/run-outside-angular.js +0 -79
- package/esm2015/lib/_common/types.js +0 -1
- package/esm2015/lib/_common/utils.js +0 -44
- package/esm2015/lib/api/contact-card.gql.js +0 -79
- package/esm2015/lib/api/contact-card.service.js +0 -154
- package/esm2015/lib/api/contact-card2.gql.js +0 -60
- package/esm2015/lib/api/contact-card2.service.js +0 -103
- package/esm2015/lib/api/file.service.js +0 -74
- package/esm2015/lib/api/item2.gql.js +0 -110
- package/esm2015/lib/api/item2.service.js +0 -311
- package/esm2015/lib/api/key-exchange.gql.js +0 -188
- package/esm2015/lib/api/key-exchange.service.js +0 -442
- package/esm2015/lib/api/key-exchange.types.js +0 -18
- package/esm2015/lib/api/key-exchange2.gql.js +0 -171
- package/esm2015/lib/api/key-exchange2.service.js +0 -479
- package/esm2015/lib/api/lock.gql.js +0 -40
- package/esm2015/lib/api/lock.service.js +0 -64
- package/esm2015/lib/api/lr-apollo.service.js +0 -46
- package/esm2015/lib/api/lr-graphql/index.js +0 -6
- package/esm2015/lib/api/lr-graphql/lr-graphql.service.js +0 -155
- package/esm2015/lib/api/lr-graphql/lr-merged-mutation.js +0 -213
- package/esm2015/lib/api/lr-graphql/lr-mutation-base.js +0 -51
- package/esm2015/lib/api/lr-graphql/lr-mutation.js +0 -48
- package/esm2015/lib/api/lr-graphql/lr.service.js +0 -18
- package/esm2015/lib/api/message.service.js +0 -138
- package/esm2015/lib/api/persist.service.js +0 -181
- package/esm2015/lib/api/query-processor/common-processors.service.js +0 -93
- package/esm2015/lib/api/query-processor/index.js +0 -3
- package/esm2015/lib/api/query-processor/query-processor.service.js +0 -192
- package/esm2015/lib/api/query-processor/tp-password-reset-processor.service.js +0 -109
- package/esm2015/lib/api/shared-contact-card.service.js +0 -119
- package/esm2015/lib/api/shared-contact-card2.gql.js +0 -41
- package/esm2015/lib/api/shared-contact-card2.service.js +0 -117
- package/esm2015/lib/api/time.service.js +0 -146
- package/esm2015/lib/api/types/graphql.types.js +0 -7
- package/esm2015/lib/api/types/index.js +0 -3
- package/esm2015/lib/api/types/lr-graphql.types.js +0 -71
- package/esm2015/lib/auth/auth.config.js +0 -57
- package/esm2015/lib/auth/auth.gql.js +0 -48
- package/esm2015/lib/auth/auth.types.js +0 -27
- package/esm2015/lib/auth/idle.service.js +0 -168
- package/esm2015/lib/auth/idle.types.js +0 -7
- package/esm2015/lib/auth/lbop.service.js +0 -355
- package/esm2015/lib/auth/life-ready-auth.service.js +0 -333
- package/esm2015/lib/auth/password.service.js +0 -320
- package/esm2015/lib/auth/register.service.js +0 -172
- package/esm2015/lib/auth/two-factor.service.js +0 -74
- package/esm2015/lib/category/category-meta.service.js +0 -99
- package/esm2015/lib/category/category.gql.js +0 -406
- package/esm2015/lib/category/category.service.js +0 -390
- package/esm2015/lib/category/category.types.js +0 -29
- package/esm2015/lib/cryptography/cryptography.types.js +0 -11
- package/esm2015/lib/cryptography/encryption.service.js +0 -189
- package/esm2015/lib/cryptography/key-factory.service.js +0 -237
- package/esm2015/lib/cryptography/key-graph.service.js +0 -280
- package/esm2015/lib/cryptography/key-meta.service.js +0 -200
- package/esm2015/lib/cryptography/key.service.js +0 -124
- package/esm2015/lib/cryptography/slip39.service.js +0 -169
- package/esm2015/lib/cryptography/web-crypto.service.js +0 -29
- package/esm2015/lib/life-ready.config.js +0 -84
- package/esm2015/lib/life-ready.module.js +0 -74
- package/esm2015/lib/plan/plan.gql.js +0 -123
- package/esm2015/lib/plan/plan.service.js +0 -149
- package/esm2015/lib/plan/plan.types.js +0 -11
- package/esm2015/lib/record/record-attachment.service.js +0 -101
- package/esm2015/lib/record/record.gql.js +0 -179
- package/esm2015/lib/record/record.service.js +0 -206
- package/esm2015/lib/record/record.types.js +0 -15
- package/esm2015/lib/record-type/record-type.service.js +0 -75
- package/esm2015/lib/record-type/record-type.types.js +0 -28
- package/esm2015/lib/scenario/approvals/scenario-approval.gql.js +0 -105
- package/esm2015/lib/scenario/approvals/scenario-approval.types.js +0 -1
- package/esm2015/lib/scenario/approvals/scenario-approver.service.js +0 -300
- package/esm2015/lib/scenario/claimants/scenario-claimant.gql.js +0 -52
- package/esm2015/lib/scenario/claimants/scenario-claimant.service.js +0 -97
- package/esm2015/lib/scenario/claimants/scenario-claimant.types.js +0 -1
- package/esm2015/lib/scenario/receivers/scenario-receiver.gql.js +0 -150
- package/esm2015/lib/scenario/receivers/scenario-receiver.service.js +0 -229
- package/esm2015/lib/scenario/receivers/scenario-receiver.types.js +0 -1
- package/esm2015/lib/scenario/scenario-setup.service.js +0 -269
- package/esm2015/lib/scenario/scenario.gql.js +0 -368
- package/esm2015/lib/scenario/scenario.service.js +0 -611
- package/esm2015/lib/scenario/scenario.types.js +0 -64
- package/esm2015/lib/search/search.gql.js +0 -62
- package/esm2015/lib/search/search.service.js +0 -156
- package/esm2015/lib/search/search.types.js +0 -6
- package/esm2015/lib/trusted-parties/tp-password-reset-request.service.js +0 -112
- package/esm2015/lib/trusted-parties/tp-password-reset-user.service.js +0 -266
- package/esm2015/lib/trusted-parties/tp-password-reset.gql.js +0 -232
- package/esm2015/lib/trusted-parties/tp-password-reset.service.js +0 -300
- package/esm2015/lib/trusted-parties/trusted-party.gql.js +0 -148
- package/esm2015/lib/trusted-parties/trusted-party.service.js +0 -326
- package/esm2015/lib/trusted-parties/trusted-party.types.js +0 -41
- package/esm2015/lib/trusted-parties/trusted-party2.gql.js +0 -87
- package/esm2015/lib/trusted-parties/trusted-party2.service.js +0 -215
- package/esm2015/lib/users/profile-details.service.js +0 -214
- package/esm2015/lib/users/profile.gql.js +0 -97
- package/esm2015/lib/users/profile.service.js +0 -169
- package/esm2015/lib/users/profile.types.js +0 -34
- package/esm2015/lib/users/user.gql.js +0 -60
- package/esm2015/lib/users/user.service.js +0 -79
- package/esm2015/lib/users/user.types.js +0 -5
- package/esm2015/lifeready-core.js +0 -10
- package/esm2015/public-api.js +0 -81
- package/fesm2015/lifeready-core.js +0 -13282
- package/fesm2015/lifeready-core.js.map +0 -1
- package/lib/_common/ast.d.ts +0 -11
- package/lib/_common/deferred-promise.d.ts +0 -12
- package/lib/_common/exceptions.d.ts +0 -109
- package/lib/_common/queries.gql.d.ts +0 -10
- package/lib/_common/run-outside-angular.d.ts +0 -14
- package/lib/_common/utils.d.ts +0 -3
- package/lib/api/contact-card.gql.d.ts +0 -7
- package/lib/api/contact-card.service.d.ts +0 -52
- package/lib/api/contact-card2.gql.d.ts +0 -34
- package/lib/api/contact-card2.service.d.ts +0 -49
- package/lib/api/file.service.d.ts +0 -18
- package/lib/api/item2.gql.d.ts +0 -96
- package/lib/api/item2.service.d.ts +0 -177
- package/lib/api/key-exchange.gql.d.ts +0 -9
- package/lib/api/key-exchange.service.d.ts +0 -39
- package/lib/api/key-exchange.types.d.ts +0 -196
- package/lib/api/key-exchange2.gql.d.ts +0 -125
- package/lib/api/key-exchange2.service.d.ts +0 -187
- package/lib/api/lock.gql.d.ts +0 -27
- package/lib/api/lock.service.d.ts +0 -25
- package/lib/api/lr-apollo.service.d.ts +0 -15
- package/lib/api/lr-graphql/lr-graphql.service.d.ts +0 -60
- package/lib/api/lr-graphql/lr-merged-mutation.d.ts +0 -27
- package/lib/api/lr-graphql/lr-mutation-base.d.ts +0 -28
- package/lib/api/lr-graphql/lr-mutation.d.ts +0 -8
- package/lib/api/lr-graphql/lr.service.d.ts +0 -9
- package/lib/api/message.service.d.ts +0 -58
- package/lib/api/persist.service.d.ts +0 -31
- package/lib/api/query-processor/common-processors.service.d.ts +0 -36
- package/lib/api/query-processor/query-processor.service.d.ts +0 -18
- package/lib/api/query-processor/tp-password-reset-processor.service.d.ts +0 -15
- package/lib/api/shared-contact-card.service.d.ts +0 -33
- package/lib/api/shared-contact-card2.gql.d.ts +0 -36
- package/lib/api/shared-contact-card2.service.d.ts +0 -45
- package/lib/api/time.service.d.ts +0 -16
- package/lib/api/types/graphql.types.d.ts +0 -29
- package/lib/api/types/lr-graphql.types.d.ts +0 -385
- package/lib/auth/auth.config.d.ts +0 -5
- package/lib/auth/auth.gql.d.ts +0 -15
- package/lib/auth/auth.types.d.ts +0 -66
- package/lib/auth/idle.service.d.ts +0 -40
- package/lib/auth/idle.types.d.ts +0 -10
- package/lib/auth/lbop.service.d.ts +0 -91
- package/lib/auth/life-ready-auth.service.d.ts +0 -46
- package/lib/auth/password.service.d.ts +0 -78
- package/lib/auth/register.service.d.ts +0 -25
- package/lib/auth/two-factor.service.d.ts +0 -15
- package/lib/category/category-meta.service.d.ts +0 -23
- package/lib/category/category.gql.d.ts +0 -45
- package/lib/category/category.service.d.ts +0 -67
- package/lib/category/category.types.d.ts +0 -79
- package/lib/cryptography/cryptography.types.d.ts +0 -83
- package/lib/cryptography/encryption.service.d.ts +0 -41
- package/lib/cryptography/key-factory.service.d.ts +0 -38
- package/lib/cryptography/key-graph.service.d.ts +0 -33
- package/lib/cryptography/key-meta.service.d.ts +0 -44
- package/lib/cryptography/key.service.d.ts +0 -36
- package/lib/cryptography/slip39.service.d.ts +0 -43
- package/lib/cryptography/web-crypto.service.d.ts +0 -5
- package/lib/life-ready.config.d.ts +0 -14
- package/lib/life-ready.module.d.ts +0 -5
- package/lib/plan/plan.gql.d.ts +0 -11
- package/lib/plan/plan.service.d.ts +0 -33
- package/lib/plan/plan.types.d.ts +0 -31
- package/lib/record/record-attachment.service.d.ts +0 -16
- package/lib/record/record.gql.d.ts +0 -14
- package/lib/record/record.service.d.ts +0 -25
- package/lib/record/record.types.d.ts +0 -57
- package/lib/record-type/record-type.service.d.ts +0 -11
- package/lib/record-type/record-type.types.d.ts +0 -50
- package/lib/scenario/approvals/scenario-approval.gql.d.ts +0 -7
- package/lib/scenario/approvals/scenario-approval.types.d.ts +0 -63
- package/lib/scenario/approvals/scenario-approver.service.d.ts +0 -32
- package/lib/scenario/claimants/scenario-claimant.gql.d.ts +0 -5
- package/lib/scenario/claimants/scenario-claimant.service.d.ts +0 -17
- package/lib/scenario/claimants/scenario-claimant.types.d.ts +0 -18
- package/lib/scenario/receivers/scenario-receiver.gql.d.ts +0 -8
- package/lib/scenario/receivers/scenario-receiver.service.d.ts +0 -30
- package/lib/scenario/receivers/scenario-receiver.types.d.ts +0 -54
- package/lib/scenario/scenario-setup.service.d.ts +0 -22
- package/lib/scenario/scenario.gql.d.ts +0 -34
- package/lib/scenario/scenario.service.d.ts +0 -58
- package/lib/scenario/scenario.types.d.ts +0 -217
- package/lib/search/search.gql.d.ts +0 -1
- package/lib/search/search.service.d.ts +0 -25
- package/lib/search/search.types.d.ts +0 -20
- package/lib/trusted-parties/tp-password-reset-request.service.d.ts +0 -20
- package/lib/trusted-parties/tp-password-reset-user.service.d.ts +0 -41
- package/lib/trusted-parties/tp-password-reset.gql.d.ts +0 -218
- package/lib/trusted-parties/tp-password-reset.service.d.ts +0 -131
- package/lib/trusted-parties/trusted-party.gql.d.ts +0 -9
- package/lib/trusted-parties/trusted-party.service.d.ts +0 -44
- package/lib/trusted-parties/trusted-party.types.d.ts +0 -102
- package/lib/trusted-parties/trusted-party2.gql.d.ts +0 -79
- package/lib/trusted-parties/trusted-party2.service.d.ts +0 -114
- package/lib/users/profile-details.service.d.ts +0 -21
- package/lib/users/profile.gql.d.ts +0 -11
- package/lib/users/profile.service.d.ts +0 -35
- package/lib/users/profile.types.d.ts +0 -96
- package/lib/users/user.gql.d.ts +0 -9
- package/lib/users/user.service.d.ts +0 -12
- package/lib/users/user.types.d.ts +0 -23
- package/lifeready-core.d.ts +0 -9
- package/lifeready-core.metadata.json +0 -1
|
@@ -1,74 +0,0 @@
|
|
|
1
|
-
import { __awaiter } from "tslib";
|
|
2
|
-
import { Injectable } from '@angular/core';
|
|
3
|
-
import { AuthClass } from '@aws-amplify/auth/lib-esm/Auth';
|
|
4
|
-
import { LrBadArgumentException } from '../_common/exceptions';
|
|
5
|
-
import * as i0 from "@angular/core";
|
|
6
|
-
import * as i1 from "@aws-amplify/auth/lib-esm/Auth";
|
|
7
|
-
export class TwoFactorService {
|
|
8
|
-
constructor(auth) {
|
|
9
|
-
this.auth = auth;
|
|
10
|
-
}
|
|
11
|
-
getPreferredMFA() {
|
|
12
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
13
|
-
const cognitoUser = yield this.auth.currentAuthenticatedUser();
|
|
14
|
-
return yield this.auth.getPreferredMFA(cognitoUser);
|
|
15
|
-
});
|
|
16
|
-
}
|
|
17
|
-
setPreferredMFA(method) {
|
|
18
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
19
|
-
const cognitoUser = yield this.auth.currentAuthenticatedUser();
|
|
20
|
-
yield this.auth.setPreferredMFA(cognitoUser, method);
|
|
21
|
-
});
|
|
22
|
-
}
|
|
23
|
-
setPhoneNumber(phone) {
|
|
24
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
25
|
-
const cognitoUser = yield this.auth.currentAuthenticatedUser();
|
|
26
|
-
yield this.auth.updateUserAttributes(cognitoUser, {
|
|
27
|
-
phone_number: phone,
|
|
28
|
-
});
|
|
29
|
-
});
|
|
30
|
-
}
|
|
31
|
-
getSMSCode() {
|
|
32
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
33
|
-
yield this.auth.verifyCurrentUserAttribute('phone_number');
|
|
34
|
-
});
|
|
35
|
-
}
|
|
36
|
-
verifySMSCode(verificationCode) {
|
|
37
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
38
|
-
yield this.auth.verifyCurrentUserAttributeSubmit('phone_number', verificationCode);
|
|
39
|
-
});
|
|
40
|
-
}
|
|
41
|
-
getSoftwareToken() {
|
|
42
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
43
|
-
const [cognitoUser, userInfo] = yield Promise.all([
|
|
44
|
-
this.auth.currentAuthenticatedUser(),
|
|
45
|
-
this.auth.currentUserInfo(),
|
|
46
|
-
]);
|
|
47
|
-
const code = yield this.auth.setupTOTP(cognitoUser);
|
|
48
|
-
const email = userInfo.attributes.email;
|
|
49
|
-
if (!email) {
|
|
50
|
-
throw new LrBadArgumentException('No email associated with user.');
|
|
51
|
-
}
|
|
52
|
-
return {
|
|
53
|
-
code,
|
|
54
|
-
codeUri: `otpauth://totp/${email}?secret=${code}&issuer=LifeReady`,
|
|
55
|
-
};
|
|
56
|
-
});
|
|
57
|
-
}
|
|
58
|
-
verifySoftwareToken(totpCode) {
|
|
59
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
60
|
-
const cognitoUser = yield this.auth.currentAuthenticatedUser();
|
|
61
|
-
yield this.auth.verifyTotpToken(cognitoUser, totpCode);
|
|
62
|
-
});
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
TwoFactorService.ɵprov = i0.ɵɵdefineInjectable({ factory: function TwoFactorService_Factory() { return new TwoFactorService(i0.ɵɵinject(i1.AuthClass)); }, token: TwoFactorService, providedIn: "root" });
|
|
66
|
-
TwoFactorService.decorators = [
|
|
67
|
-
{ type: Injectable, args: [{
|
|
68
|
-
providedIn: 'root',
|
|
69
|
-
},] }
|
|
70
|
-
];
|
|
71
|
-
TwoFactorService.ctorParameters = () => [
|
|
72
|
-
{ type: AuthClass }
|
|
73
|
-
];
|
|
74
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHdvLWZhY3Rvci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6Ii9vcHQvYXRsYXNzaWFuL3BpcGVsaW5lcy9hZ2VudC9idWlsZC9wcm9qZWN0cy9jb3JlL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9hdXRoL3R3by1mYWN0b3Iuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUzQyxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDM0QsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7OztBQUsvRCxNQUFNLE9BQU8sZ0JBQWdCO0lBQzNCLFlBQW9CLElBQWU7UUFBZixTQUFJLEdBQUosSUFBSSxDQUFXO0lBQUcsQ0FBQztJQUUxQixlQUFlOztZQUMxQixNQUFNLFdBQVcsR0FBZ0IsTUFBTSxJQUFJLENBQUMsSUFBSSxDQUFDLHdCQUF3QixFQUFFLENBQUM7WUFFNUUsT0FBTyxNQUFNLElBQUksQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQ3RELENBQUM7S0FBQTtJQUVZLGVBQWUsQ0FDMUIsTUFBZ0M7O1lBRWhDLE1BQU0sV0FBVyxHQUFnQixNQUFNLElBQUksQ0FBQyxJQUFJLENBQUMsd0JBQXdCLEVBQUUsQ0FBQztZQUU1RSxNQUFNLElBQUksQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLFdBQVcsRUFBRSxNQUFNLENBQUMsQ0FBQztRQUN2RCxDQUFDO0tBQUE7SUFFWSxjQUFjLENBQUMsS0FBSzs7WUFDL0IsTUFBTSxXQUFXLEdBQWdCLE1BQU0sSUFBSSxDQUFDLElBQUksQ0FBQyx3QkFBd0IsRUFBRSxDQUFDO1lBRTVFLE1BQU0sSUFBSSxDQUFDLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxXQUFXLEVBQUU7Z0JBQ2hELFlBQVksRUFBRSxLQUFLO2FBQ3BCLENBQUMsQ0FBQztRQUNMLENBQUM7S0FBQTtJQUVZLFVBQVU7O1lBQ3JCLE1BQU0sSUFBSSxDQUFDLElBQUksQ0FBQywwQkFBMEIsQ0FBQyxjQUFjLENBQUMsQ0FBQztRQUM3RCxDQUFDO0tBQUE7SUFFWSxhQUFhLENBQUMsZ0JBQXdCOztZQUNqRCxNQUFNLElBQUksQ0FBQyxJQUFJLENBQUMsZ0NBQWdDLENBQzlDLGNBQWMsRUFDZCxnQkFBZ0IsQ0FDakIsQ0FBQztRQUNKLENBQUM7S0FBQTtJQUVZLGdCQUFnQjs7WUFDM0IsTUFBTSxDQUFDLFdBQVcsRUFBRSxRQUFRLENBQUMsR0FBRyxNQUFNLE9BQU8sQ0FBQyxHQUFHLENBQUM7Z0JBQ2hELElBQUksQ0FBQyxJQUFJLENBQUMsd0JBQXdCLEVBQUU7Z0JBQ3BDLElBQUksQ0FBQyxJQUFJLENBQUMsZUFBZSxFQUFFO2FBQzVCLENBQUMsQ0FBQztZQUVILE1BQU0sSUFBSSxHQUFHLE1BQU0sSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsV0FBVyxDQUFDLENBQUM7WUFFcEQsTUFBTSxLQUFLLEdBQUcsUUFBUSxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUM7WUFDeEMsSUFBSSxDQUFDLEtBQUssRUFBRTtnQkFDVixNQUFNLElBQUksc0JBQXNCLENBQUMsZ0NBQWdDLENBQUMsQ0FBQzthQUNwRTtZQUVELE9BQU87Z0JBQ0wsSUFBSTtnQkFDSixPQUFPLEVBQUUsa0JBQWtCLEtBQUssV0FBVyxJQUFJLG1CQUFtQjthQUNuRSxDQUFDO1FBQ0osQ0FBQztLQUFBO0lBRVksbUJBQW1CLENBQUMsUUFBZ0I7O1lBQy9DLE1BQU0sV0FBVyxHQUFnQixNQUFNLElBQUksQ0FBQyxJQUFJLENBQUMsd0JBQXdCLEVBQUUsQ0FBQztZQUU1RSxNQUFNLElBQUksQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLFdBQVcsRUFBRSxRQUFRLENBQUMsQ0FBQztRQUN6RCxDQUFDO0tBQUE7Ozs7WUE5REYsVUFBVSxTQUFDO2dCQUNWLFVBQVUsRUFBRSxNQUFNO2FBQ25COzs7WUFMUSxTQUFTIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29nbml0b1VzZXIgfSBmcm9tICdAYXdzLWFtcGxpZnkvYXV0aCc7XG5pbXBvcnQgeyBBdXRoQ2xhc3MgfSBmcm9tICdAYXdzLWFtcGxpZnkvYXV0aC9saWItZXNtL0F1dGgnO1xuaW1wb3J0IHsgTHJCYWRBcmd1bWVudEV4Y2VwdGlvbiB9IGZyb20gJy4uL19jb21tb24vZXhjZXB0aW9ucyc7XG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxufSlcbmV4cG9ydCBjbGFzcyBUd29GYWN0b3JTZXJ2aWNlIHtcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBhdXRoOiBBdXRoQ2xhc3MpIHt9XG5cbiAgcHVibGljIGFzeW5jIGdldFByZWZlcnJlZE1GQSgpOiBQcm9taXNlPHN0cmluZz4ge1xuICAgIGNvbnN0IGNvZ25pdG9Vc2VyOiBDb2duaXRvVXNlciA9IGF3YWl0IHRoaXMuYXV0aC5jdXJyZW50QXV0aGVudGljYXRlZFVzZXIoKTtcblxuICAgIHJldHVybiBhd2FpdCB0aGlzLmF1dGguZ2V0UHJlZmVycmVkTUZBKGNvZ25pdG9Vc2VyKTtcbiAgfVxuXG4gIHB1YmxpYyBhc3luYyBzZXRQcmVmZXJyZWRNRkEoXG4gICAgbWV0aG9kOiAnVE9UUCcgfCAnU01TJyB8ICdOT01GQSdcbiAgKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgY29uc3QgY29nbml0b1VzZXI6IENvZ25pdG9Vc2VyID0gYXdhaXQgdGhpcy5hdXRoLmN1cnJlbnRBdXRoZW50aWNhdGVkVXNlcigpO1xuXG4gICAgYXdhaXQgdGhpcy5hdXRoLnNldFByZWZlcnJlZE1GQShjb2duaXRvVXNlciwgbWV0aG9kKTtcbiAgfVxuXG4gIHB1YmxpYyBhc3luYyBzZXRQaG9uZU51bWJlcihwaG9uZSk6IFByb21pc2U8dm9pZD4ge1xuICAgIGNvbnN0IGNvZ25pdG9Vc2VyOiBDb2duaXRvVXNlciA9IGF3YWl0IHRoaXMuYXV0aC5jdXJyZW50QXV0aGVudGljYXRlZFVzZXIoKTtcblxuICAgIGF3YWl0IHRoaXMuYXV0aC51cGRhdGVVc2VyQXR0cmlidXRlcyhjb2duaXRvVXNlciwge1xuICAgICAgcGhvbmVfbnVtYmVyOiBwaG9uZSxcbiAgICB9KTtcbiAgfVxuXG4gIHB1YmxpYyBhc3luYyBnZXRTTVNDb2RlKCkge1xuICAgIGF3YWl0IHRoaXMuYXV0aC52ZXJpZnlDdXJyZW50VXNlckF0dHJpYnV0ZSgncGhvbmVfbnVtYmVyJyk7XG4gIH1cblxuICBwdWJsaWMgYXN5bmMgdmVyaWZ5U01TQ29kZSh2ZXJpZmljYXRpb25Db2RlOiBzdHJpbmcpIHtcbiAgICBhd2FpdCB0aGlzLmF1dGgudmVyaWZ5Q3VycmVudFVzZXJBdHRyaWJ1dGVTdWJtaXQoXG4gICAgICAncGhvbmVfbnVtYmVyJyxcbiAgICAgIHZlcmlmaWNhdGlvbkNvZGVcbiAgICApO1xuICB9XG5cbiAgcHVibGljIGFzeW5jIGdldFNvZnR3YXJlVG9rZW4oKTogUHJvbWlzZTx7IGNvZGU6IHN0cmluZzsgY29kZVVyaTogc3RyaW5nIH0+IHtcbiAgICBjb25zdCBbY29nbml0b1VzZXIsIHVzZXJJbmZvXSA9IGF3YWl0IFByb21pc2UuYWxsKFtcbiAgICAgIHRoaXMuYXV0aC5jdXJyZW50QXV0aGVudGljYXRlZFVzZXIoKSxcbiAgICAgIHRoaXMuYXV0aC5jdXJyZW50VXNlckluZm8oKSxcbiAgICBdKTtcblxuICAgIGNvbnN0IGNvZGUgPSBhd2FpdCB0aGlzLmF1dGguc2V0dXBUT1RQKGNvZ25pdG9Vc2VyKTtcblxuICAgIGNvbnN0IGVtYWlsID0gdXNlckluZm8uYXR0cmlidXRlcy5lbWFpbDtcbiAgICBpZiAoIWVtYWlsKSB7XG4gICAgICB0aHJvdyBuZXcgTHJCYWRBcmd1bWVudEV4Y2VwdGlvbignTm8gZW1haWwgYXNzb2NpYXRlZCB3aXRoIHVzZXIuJyk7XG4gICAgfVxuXG4gICAgcmV0dXJuIHtcbiAgICAgIGNvZGUsXG4gICAgICBjb2RlVXJpOiBgb3RwYXV0aDovL3RvdHAvJHtlbWFpbH0/c2VjcmV0PSR7Y29kZX0maXNzdWVyPUxpZmVSZWFkeWAsXG4gICAgfTtcbiAgfVxuXG4gIHB1YmxpYyBhc3luYyB2ZXJpZnlTb2Z0d2FyZVRva2VuKHRvdHBDb2RlOiBzdHJpbmcpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBjb25zdCBjb2duaXRvVXNlcjogQ29nbml0b1VzZXIgPSBhd2FpdCB0aGlzLmF1dGguY3VycmVudEF1dGhlbnRpY2F0ZWRVc2VyKCk7XG5cbiAgICBhd2FpdCB0aGlzLmF1dGgudmVyaWZ5VG90cFRva2VuKGNvZ25pdG9Vc2VyLCB0b3RwQ29kZSk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -1,99 +0,0 @@
|
|
|
1
|
-
import { __awaiter } from "tslib";
|
|
2
|
-
import { HttpClient } from '@angular/common/http';
|
|
3
|
-
import { Injectable } from '@angular/core';
|
|
4
|
-
import { CategoryService } from './category.service';
|
|
5
|
-
import * as i0 from "@angular/core";
|
|
6
|
-
import * as i1 from "@angular/common/http";
|
|
7
|
-
import * as i2 from "./category.service";
|
|
8
|
-
export class LoadedCategoryTree {
|
|
9
|
-
}
|
|
10
|
-
export class CategoryMetaService {
|
|
11
|
-
constructor(http, categoryService) {
|
|
12
|
-
this.http = http;
|
|
13
|
-
this.categoryService = categoryService;
|
|
14
|
-
}
|
|
15
|
-
getCoreCategories() {
|
|
16
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
17
|
-
if (!this.categories) {
|
|
18
|
-
this.categories = yield this.http
|
|
19
|
-
.get('/assets/meta/categories.json')
|
|
20
|
-
.toPromise();
|
|
21
|
-
}
|
|
22
|
-
return Promise.resolve(this.categories);
|
|
23
|
-
});
|
|
24
|
-
}
|
|
25
|
-
loadCategories(categoryTrees, selectedCategoryId, trustedPartyId) {
|
|
26
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
27
|
-
const rootCategories = trustedPartyId
|
|
28
|
-
? (yield this.categoryService.getTrustedPartyCategories(trustedPartyId))
|
|
29
|
-
.categories
|
|
30
|
-
: yield this.categoryService.getCategories();
|
|
31
|
-
const selectedCategory = selectedCategoryId
|
|
32
|
-
? yield this.categoryService.getCategory(selectedCategoryId)
|
|
33
|
-
: null;
|
|
34
|
-
const categoryPromises = categoryTrees.map((x) => __awaiter(this, void 0, void 0, function* () {
|
|
35
|
-
return ({
|
|
36
|
-
categoryTree: x,
|
|
37
|
-
category: yield this.loadCategory([...x], rootCategories, selectedCategory),
|
|
38
|
-
});
|
|
39
|
-
}));
|
|
40
|
-
const loadedCategories = yield Promise.all(categoryPromises);
|
|
41
|
-
const loadedCategoryTree = {
|
|
42
|
-
categories: [],
|
|
43
|
-
missingCategories: [],
|
|
44
|
-
};
|
|
45
|
-
loadedCategories.forEach((x) => x.category
|
|
46
|
-
? loadedCategoryTree.categories.push(x.category)
|
|
47
|
-
: loadedCategoryTree.missingCategories.push(x.categoryTree));
|
|
48
|
-
return loadedCategoryTree;
|
|
49
|
-
});
|
|
50
|
-
}
|
|
51
|
-
loadCategoriesForRole(categories) {
|
|
52
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
53
|
-
const rootCategories = yield this.categoryService.getCategories();
|
|
54
|
-
return yield Promise.all(categories.map((x) => __awaiter(this, void 0, void 0, function* () {
|
|
55
|
-
return ({
|
|
56
|
-
category: yield this.loadCategory([...x.category], rootCategories),
|
|
57
|
-
accessLevel: x.accessLevel,
|
|
58
|
-
});
|
|
59
|
-
})));
|
|
60
|
-
});
|
|
61
|
-
}
|
|
62
|
-
loadCategory(categoryTree, categories, selectedCategory) {
|
|
63
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
64
|
-
const name = categoryTree.shift();
|
|
65
|
-
const currentCategory = categories.find((x) => x.code === name && !x.isCustom);
|
|
66
|
-
if (currentCategory) {
|
|
67
|
-
if (categoryTree.length) {
|
|
68
|
-
const { subCategories } = yield this.categoryService.getCategory(currentCategory.id);
|
|
69
|
-
return this.loadCategory(categoryTree, subCategories, selectedCategory);
|
|
70
|
-
}
|
|
71
|
-
else {
|
|
72
|
-
const { category } = yield this.categoryService.getCategory(currentCategory.id);
|
|
73
|
-
if (selectedCategory &&
|
|
74
|
-
selectedCategory.category.parents.some((x) => x.id === category.id)) {
|
|
75
|
-
return selectedCategory.category;
|
|
76
|
-
}
|
|
77
|
-
return category;
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
else if (categoryTree.length) {
|
|
81
|
-
return this.loadCategory(categoryTree, categories, selectedCategory);
|
|
82
|
-
}
|
|
83
|
-
else {
|
|
84
|
-
return null;
|
|
85
|
-
}
|
|
86
|
-
});
|
|
87
|
-
}
|
|
88
|
-
}
|
|
89
|
-
CategoryMetaService.ɵprov = i0.ɵɵdefineInjectable({ factory: function CategoryMetaService_Factory() { return new CategoryMetaService(i0.ɵɵinject(i1.HttpClient), i0.ɵɵinject(i2.CategoryService)); }, token: CategoryMetaService, providedIn: "root" });
|
|
90
|
-
CategoryMetaService.decorators = [
|
|
91
|
-
{ type: Injectable, args: [{
|
|
92
|
-
providedIn: 'root',
|
|
93
|
-
},] }
|
|
94
|
-
];
|
|
95
|
-
CategoryMetaService.ctorParameters = () => [
|
|
96
|
-
{ type: HttpClient },
|
|
97
|
-
{ type: CategoryService }
|
|
98
|
-
];
|
|
99
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2F0ZWdvcnktbWV0YS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6Ii9vcHQvYXRsYXNzaWFuL3BpcGVsaW5lcy9hZ2VudC9idWlsZC9wcm9qZWN0cy9jb3JlL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9jYXRlZ29yeS9jYXRlZ29yeS1tZXRhLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUNsRCxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQzs7OztBQVNyRCxNQUFNLE9BQU8sa0JBQWtCO0NBRzlCO0FBS0QsTUFBTSxPQUFPLG1CQUFtQjtJQUc5QixZQUNVLElBQWdCLEVBQ2hCLGVBQWdDO1FBRGhDLFNBQUksR0FBSixJQUFJLENBQVk7UUFDaEIsb0JBQWUsR0FBZixlQUFlLENBQWlCO0lBQ3ZDLENBQUM7SUFFUyxpQkFBaUI7O1lBQzVCLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxFQUFFO2dCQUNwQixJQUFJLENBQUMsVUFBVSxHQUFHLE1BQU0sSUFBSSxDQUFDLElBQUk7cUJBQzlCLEdBQUcsQ0FBb0IsOEJBQThCLENBQUM7cUJBQ3RELFNBQVMsRUFBRSxDQUFDO2FBQ2hCO1lBQ0QsT0FBTyxPQUFPLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUMxQyxDQUFDO0tBQUE7SUFFSyxjQUFjLENBQ2xCLGFBQXlCLEVBQ3pCLGtCQUEyQixFQUMzQixjQUF1Qjs7WUFFdkIsTUFBTSxjQUFjLEdBQUcsY0FBYztnQkFDbkMsQ0FBQyxDQUFDLENBQUMsTUFBTSxJQUFJLENBQUMsZUFBZSxDQUFDLHlCQUF5QixDQUFDLGNBQWMsQ0FBQyxDQUFDO3FCQUNuRSxVQUFVO2dCQUNmLENBQUMsQ0FBQyxNQUFNLElBQUksQ0FBQyxlQUFlLENBQUMsYUFBYSxFQUFFLENBQUM7WUFFL0MsTUFBTSxnQkFBZ0IsR0FBRyxrQkFBa0I7Z0JBQ3pDLENBQUMsQ0FBQyxNQUFNLElBQUksQ0FBQyxlQUFlLENBQUMsV0FBVyxDQUFDLGtCQUFrQixDQUFDO2dCQUM1RCxDQUFDLENBQUMsSUFBSSxDQUFDO1lBRVQsTUFBTSxnQkFBZ0IsR0FBRyxhQUFhLENBQUMsR0FBRyxDQUFDLENBQU8sQ0FBQyxFQUFFLEVBQUU7Z0JBQUMsT0FBQSxDQUFDO29CQUN2RCxZQUFZLEVBQUUsQ0FBQztvQkFDZixRQUFRLEVBQUUsTUFBTSxJQUFJLENBQUMsWUFBWSxDQUMvQixDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQ04sY0FBYyxFQUNkLGdCQUFnQixDQUNqQjtpQkFDRixDQUFDLENBQUE7Y0FBQSxDQUFDLENBQUM7WUFFSixNQUFNLGdCQUFnQixHQUFHLE1BQU0sT0FBTyxDQUFDLEdBQUcsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1lBRTdELE1BQU0sa0JBQWtCLEdBQXVCO2dCQUM3QyxVQUFVLEVBQUUsRUFBRTtnQkFDZCxpQkFBaUIsRUFBRSxFQUFFO2FBQ3RCLENBQUM7WUFFRixnQkFBZ0IsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUM3QixDQUFDLENBQUMsUUFBUTtnQkFDUixDQUFDLENBQUMsa0JBQWtCLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDO2dCQUNoRCxDQUFDLENBQUMsa0JBQWtCLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxZQUFZLENBQUMsQ0FDOUQsQ0FBQztZQUVGLE9BQU8sa0JBQWtCLENBQUM7UUFDNUIsQ0FBQztLQUFBO0lBRUsscUJBQXFCLENBQ3pCLFVBQThEOztZQUU5RCxNQUFNLGNBQWMsR0FBRyxNQUFNLElBQUksQ0FBQyxlQUFlLENBQUMsYUFBYSxFQUFFLENBQUM7WUFFbEUsT0FBTyxNQUFNLE9BQU8sQ0FBQyxHQUFHLENBQ3RCLFVBQVUsQ0FBQyxHQUFHLENBQUMsQ0FBTyxDQUFDLEVBQUUsRUFBRTtnQkFBQyxPQUFBLENBQUM7b0JBQzNCLFFBQVEsRUFBRSxNQUFNLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxRQUFRLENBQUMsRUFBRSxjQUFjLENBQUM7b0JBQ2xFLFdBQVcsRUFBRSxDQUFDLENBQUMsV0FBVztpQkFDM0IsQ0FBQyxDQUFBO2NBQUEsQ0FBQyxDQUNKLENBQUM7UUFDSixDQUFDO0tBQUE7SUFFYSxZQUFZLENBQ3hCLFlBQXNCLEVBQ3RCLFVBQXNCLEVBQ3RCLGdCQUFnQzs7WUFFaEMsTUFBTSxJQUFJLEdBQUcsWUFBWSxDQUFDLEtBQUssRUFBRSxDQUFDO1lBRWxDLE1BQU0sZUFBZSxHQUFHLFVBQVUsQ0FBQyxJQUFJLENBQ3JDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxLQUFLLElBQUksSUFBSSxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQ3RDLENBQUM7WUFFRixJQUFJLGVBQWUsRUFBRTtnQkFDbkIsSUFBSSxZQUFZLENBQUMsTUFBTSxFQUFFO29CQUN2QixNQUFNLEVBQUUsYUFBYSxFQUFFLEdBQUcsTUFBTSxJQUFJLENBQUMsZUFBZSxDQUFDLFdBQVcsQ0FDOUQsZUFBZSxDQUFDLEVBQUUsQ0FDbkIsQ0FBQztvQkFDRixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsWUFBWSxFQUFFLGFBQWEsRUFBRSxnQkFBZ0IsQ0FBQyxDQUFDO2lCQUN6RTtxQkFBTTtvQkFDTCxNQUFNLEVBQUUsUUFBUSxFQUFFLEdBQUcsTUFBTSxJQUFJLENBQUMsZUFBZSxDQUFDLFdBQVcsQ0FDekQsZUFBZSxDQUFDLEVBQUUsQ0FDbkIsQ0FBQztvQkFFRixJQUNFLGdCQUFnQjt3QkFDaEIsZ0JBQWdCLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFFLEtBQUssUUFBUSxDQUFDLEVBQUUsQ0FBQyxFQUNuRTt3QkFDQSxPQUFPLGdCQUFnQixDQUFDLFFBQVEsQ0FBQztxQkFDbEM7b0JBQ0QsT0FBTyxRQUFRLENBQUM7aUJBQ2pCO2FBQ0Y7aUJBQU0sSUFBSSxZQUFZLENBQUMsTUFBTSxFQUFFO2dCQUM5QixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsWUFBWSxFQUFFLFVBQVUsRUFBRSxnQkFBZ0IsQ0FBQyxDQUFDO2FBQ3RFO2lCQUFNO2dCQUNMLE9BQU8sSUFBSSxDQUFDO2FBQ2I7UUFDSCxDQUFDO0tBQUE7Ozs7WUEzR0YsVUFBVSxTQUFDO2dCQUNWLFVBQVUsRUFBRSxNQUFNO2FBQ25COzs7WUFsQlEsVUFBVTtZQUVWLGVBQWUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBIdHRwQ2xpZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ2F0ZWdvcnlTZXJ2aWNlIH0gZnJvbSAnLi9jYXRlZ29yeS5zZXJ2aWNlJztcbmltcG9ydCB7XG4gIEFjY2Vzc0xldmVsLFxuICBDYXRlZ29yeSxcbiAgQ3VycmVudENhdGVnb3J5LFxuICBEZWZhdWx0Q2F0ZWdvcnksXG4gIFZhdWx0Q2F0ZWdvcnksXG59IGZyb20gJy4vY2F0ZWdvcnkudHlwZXMnO1xuXG5leHBvcnQgY2xhc3MgTG9hZGVkQ2F0ZWdvcnlUcmVlIHtcbiAgY2F0ZWdvcmllczogQ3VycmVudENhdGVnb3J5W107XG4gIG1pc3NpbmdDYXRlZ29yaWVzOiBzdHJpbmdbXVtdO1xufVxuXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290Jyxcbn0pXG5leHBvcnQgY2xhc3MgQ2F0ZWdvcnlNZXRhU2VydmljZSB7XG4gIHByaXZhdGUgY2F0ZWdvcmllczogRGVmYXVsdENhdGVnb3J5W107XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSBodHRwOiBIdHRwQ2xpZW50LFxuICAgIHByaXZhdGUgY2F0ZWdvcnlTZXJ2aWNlOiBDYXRlZ29yeVNlcnZpY2VcbiAgKSB7fVxuXG4gIHB1YmxpYyBhc3luYyBnZXRDb3JlQ2F0ZWdvcmllcygpOiBQcm9taXNlPERlZmF1bHRDYXRlZ29yeVtdPiB7XG4gICAgaWYgKCF0aGlzLmNhdGVnb3JpZXMpIHtcbiAgICAgIHRoaXMuY2F0ZWdvcmllcyA9IGF3YWl0IHRoaXMuaHR0cFxuICAgICAgICAuZ2V0PERlZmF1bHRDYXRlZ29yeVtdPignL2Fzc2V0cy9tZXRhL2NhdGVnb3JpZXMuanNvbicpXG4gICAgICAgIC50b1Byb21pc2UoKTtcbiAgICB9XG4gICAgcmV0dXJuIFByb21pc2UucmVzb2x2ZSh0aGlzLmNhdGVnb3JpZXMpO1xuICB9XG5cbiAgYXN5bmMgbG9hZENhdGVnb3JpZXMoXG4gICAgY2F0ZWdvcnlUcmVlczogc3RyaW5nW11bXSxcbiAgICBzZWxlY3RlZENhdGVnb3J5SWQ/OiBzdHJpbmcsXG4gICAgdHJ1c3RlZFBhcnR5SWQ/OiBzdHJpbmdcbiAgKTogUHJvbWlzZTxMb2FkZWRDYXRlZ29yeVRyZWU+IHtcbiAgICBjb25zdCByb290Q2F0ZWdvcmllcyA9IHRydXN0ZWRQYXJ0eUlkXG4gICAgICA/IChhd2FpdCB0aGlzLmNhdGVnb3J5U2VydmljZS5nZXRUcnVzdGVkUGFydHlDYXRlZ29yaWVzKHRydXN0ZWRQYXJ0eUlkKSlcbiAgICAgICAgICAuY2F0ZWdvcmllc1xuICAgICAgOiBhd2FpdCB0aGlzLmNhdGVnb3J5U2VydmljZS5nZXRDYXRlZ29yaWVzKCk7XG5cbiAgICBjb25zdCBzZWxlY3RlZENhdGVnb3J5ID0gc2VsZWN0ZWRDYXRlZ29yeUlkXG4gICAgICA/IGF3YWl0IHRoaXMuY2F0ZWdvcnlTZXJ2aWNlLmdldENhdGVnb3J5KHNlbGVjdGVkQ2F0ZWdvcnlJZClcbiAgICAgIDogbnVsbDtcblxuICAgIGNvbnN0IGNhdGVnb3J5UHJvbWlzZXMgPSBjYXRlZ29yeVRyZWVzLm1hcChhc3luYyAoeCkgPT4gKHtcbiAgICAgIGNhdGVnb3J5VHJlZTogeCxcbiAgICAgIGNhdGVnb3J5OiBhd2FpdCB0aGlzLmxvYWRDYXRlZ29yeShcbiAgICAgICAgWy4uLnhdLFxuICAgICAgICByb290Q2F0ZWdvcmllcyxcbiAgICAgICAgc2VsZWN0ZWRDYXRlZ29yeVxuICAgICAgKSxcbiAgICB9KSk7XG5cbiAgICBjb25zdCBsb2FkZWRDYXRlZ29yaWVzID0gYXdhaXQgUHJvbWlzZS5hbGwoY2F0ZWdvcnlQcm9taXNlcyk7XG5cbiAgICBjb25zdCBsb2FkZWRDYXRlZ29yeVRyZWU6IExvYWRlZENhdGVnb3J5VHJlZSA9IHtcbiAgICAgIGNhdGVnb3JpZXM6IFtdLFxuICAgICAgbWlzc2luZ0NhdGVnb3JpZXM6IFtdLFxuICAgIH07XG5cbiAgICBsb2FkZWRDYXRlZ29yaWVzLmZvckVhY2goKHgpID0+XG4gICAgICB4LmNhdGVnb3J5XG4gICAgICAgID8gbG9hZGVkQ2F0ZWdvcnlUcmVlLmNhdGVnb3JpZXMucHVzaCh4LmNhdGVnb3J5KVxuICAgICAgICA6IGxvYWRlZENhdGVnb3J5VHJlZS5taXNzaW5nQ2F0ZWdvcmllcy5wdXNoKHguY2F0ZWdvcnlUcmVlKVxuICAgICk7XG5cbiAgICByZXR1cm4gbG9hZGVkQ2F0ZWdvcnlUcmVlO1xuICB9XG5cbiAgYXN5bmMgbG9hZENhdGVnb3JpZXNGb3JSb2xlKFxuICAgIGNhdGVnb3JpZXM6IHsgY2F0ZWdvcnk6IHN0cmluZ1tdOyBhY2Nlc3NMZXZlbDogQWNjZXNzTGV2ZWwgfVtdXG4gICk6IFByb21pc2U8eyBjYXRlZ29yeTogQ3VycmVudENhdGVnb3J5OyBhY2Nlc3NMZXZlbDogQWNjZXNzTGV2ZWwgfVtdPiB7XG4gICAgY29uc3Qgcm9vdENhdGVnb3JpZXMgPSBhd2FpdCB0aGlzLmNhdGVnb3J5U2VydmljZS5nZXRDYXRlZ29yaWVzKCk7XG5cbiAgICByZXR1cm4gYXdhaXQgUHJvbWlzZS5hbGwoXG4gICAgICBjYXRlZ29yaWVzLm1hcChhc3luYyAoeCkgPT4gKHtcbiAgICAgICAgY2F0ZWdvcnk6IGF3YWl0IHRoaXMubG9hZENhdGVnb3J5KFsuLi54LmNhdGVnb3J5XSwgcm9vdENhdGVnb3JpZXMpLFxuICAgICAgICBhY2Nlc3NMZXZlbDogeC5hY2Nlc3NMZXZlbCxcbiAgICAgIH0pKVxuICAgICk7XG4gIH1cblxuICBwcml2YXRlIGFzeW5jIGxvYWRDYXRlZ29yeShcbiAgICBjYXRlZ29yeVRyZWU6IHN0cmluZ1tdLFxuICAgIGNhdGVnb3JpZXM6IENhdGVnb3J5W10sXG4gICAgc2VsZWN0ZWRDYXRlZ29yeT86IFZhdWx0Q2F0ZWdvcnlcbiAgKTogUHJvbWlzZTxDdXJyZW50Q2F0ZWdvcnk+IHtcbiAgICBjb25zdCBuYW1lID0gY2F0ZWdvcnlUcmVlLnNoaWZ0KCk7XG5cbiAgICBjb25zdCBjdXJyZW50Q2F0ZWdvcnkgPSBjYXRlZ29yaWVzLmZpbmQoXG4gICAgICAoeCkgPT4geC5jb2RlID09PSBuYW1lICYmICF4LmlzQ3VzdG9tXG4gICAgKTtcblxuICAgIGlmIChjdXJyZW50Q2F0ZWdvcnkpIHtcbiAgICAgIGlmIChjYXRlZ29yeVRyZWUubGVuZ3RoKSB7XG4gICAgICAgIGNvbnN0IHsgc3ViQ2F0ZWdvcmllcyB9ID0gYXdhaXQgdGhpcy5jYXRlZ29yeVNlcnZpY2UuZ2V0Q2F0ZWdvcnkoXG4gICAgICAgICAgY3VycmVudENhdGVnb3J5LmlkXG4gICAgICAgICk7XG4gICAgICAgIHJldHVybiB0aGlzLmxvYWRDYXRlZ29yeShjYXRlZ29yeVRyZWUsIHN1YkNhdGVnb3JpZXMsIHNlbGVjdGVkQ2F0ZWdvcnkpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgY29uc3QgeyBjYXRlZ29yeSB9ID0gYXdhaXQgdGhpcy5jYXRlZ29yeVNlcnZpY2UuZ2V0Q2F0ZWdvcnkoXG4gICAgICAgICAgY3VycmVudENhdGVnb3J5LmlkXG4gICAgICAgICk7XG5cbiAgICAgICAgaWYgKFxuICAgICAgICAgIHNlbGVjdGVkQ2F0ZWdvcnkgJiZcbiAgICAgICAgICBzZWxlY3RlZENhdGVnb3J5LmNhdGVnb3J5LnBhcmVudHMuc29tZSgoeCkgPT4geC5pZCA9PT0gY2F0ZWdvcnkuaWQpXG4gICAgICAgICkge1xuICAgICAgICAgIHJldHVybiBzZWxlY3RlZENhdGVnb3J5LmNhdGVnb3J5O1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiBjYXRlZ29yeTtcbiAgICAgIH1cbiAgICB9IGVsc2UgaWYgKGNhdGVnb3J5VHJlZS5sZW5ndGgpIHtcbiAgICAgIHJldHVybiB0aGlzLmxvYWRDYXRlZ29yeShjYXRlZ29yeVRyZWUsIGNhdGVnb3JpZXMsIHNlbGVjdGVkQ2F0ZWdvcnkpO1xuICAgIH0gZWxzZSB7XG4gICAgICByZXR1cm4gbnVsbDtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
|
|
@@ -1,406 +0,0 @@
|
|
|
1
|
-
import { KeyGraphFragment } from '../_common/queries.gql';
|
|
2
|
-
import gql from 'graphql-tag';
|
|
3
|
-
export const DEFAULT_BREADCRUMB_DEPTH = 5;
|
|
4
|
-
export const DEFAULT_DESCENDANTS_DEPTH = 5;
|
|
5
|
-
export var DirectoryType;
|
|
6
|
-
(function (DirectoryType) {
|
|
7
|
-
DirectoryType["Vault"] = "vault";
|
|
8
|
-
DirectoryType["Category"] = "category";
|
|
9
|
-
DirectoryType["Record"] = "record";
|
|
10
|
-
})(DirectoryType || (DirectoryType = {}));
|
|
11
|
-
export const DefaultVaultFilter = JSON.stringify({
|
|
12
|
-
filter: [
|
|
13
|
-
{
|
|
14
|
-
contains: {
|
|
15
|
-
directoryType: DirectoryType.Vault,
|
|
16
|
-
default: true,
|
|
17
|
-
},
|
|
18
|
-
},
|
|
19
|
-
],
|
|
20
|
-
});
|
|
21
|
-
export const CategoryFilter = JSON.stringify({
|
|
22
|
-
filter: [
|
|
23
|
-
{
|
|
24
|
-
contains: {
|
|
25
|
-
directoryType: DirectoryType.Category,
|
|
26
|
-
},
|
|
27
|
-
},
|
|
28
|
-
],
|
|
29
|
-
});
|
|
30
|
-
export const RecordFilter = JSON.stringify({
|
|
31
|
-
filter: [
|
|
32
|
-
{
|
|
33
|
-
contains: {
|
|
34
|
-
directoryType: DirectoryType.Record,
|
|
35
|
-
},
|
|
36
|
-
},
|
|
37
|
-
],
|
|
38
|
-
});
|
|
39
|
-
export const AccessFields = `
|
|
40
|
-
accessRoles {
|
|
41
|
-
role
|
|
42
|
-
method
|
|
43
|
-
inheritedFrom {
|
|
44
|
-
id
|
|
45
|
-
}
|
|
46
|
-
trustedParty {
|
|
47
|
-
id
|
|
48
|
-
}
|
|
49
|
-
isIssuer
|
|
50
|
-
}`;
|
|
51
|
-
const descendantDirectories = `
|
|
52
|
-
descendantDirectories(depth: ${DEFAULT_DESCENDANTS_DEPTH}, plainMeta: $categoryFilter, archived: false) {
|
|
53
|
-
recordsCount: directoriesCount(plainMeta: $recordFilter, archived: false)
|
|
54
|
-
}
|
|
55
|
-
`;
|
|
56
|
-
export const CategoryFields = `
|
|
57
|
-
id
|
|
58
|
-
keyId
|
|
59
|
-
archived
|
|
60
|
-
plainMeta
|
|
61
|
-
cipherMeta
|
|
62
|
-
${AccessFields}
|
|
63
|
-
${descendantDirectories}
|
|
64
|
-
`;
|
|
65
|
-
export const VaultFields = `
|
|
66
|
-
id
|
|
67
|
-
keyId
|
|
68
|
-
plainMeta
|
|
69
|
-
cipherMeta
|
|
70
|
-
`;
|
|
71
|
-
export const GetRootDirectoryIdsQuery = gql `
|
|
72
|
-
query GetRootDirectoryIdsQuery($archived: Boolean) {
|
|
73
|
-
rootDirectories(archived: $archived) {
|
|
74
|
-
edges {
|
|
75
|
-
node {
|
|
76
|
-
id
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
`;
|
|
82
|
-
export const GetCategoriesQuery = gql `
|
|
83
|
-
query GetCategories($vaultFilter: LrJSONFilter!, $categoryFilter: LrJSONFilter!, $recordFilter: LrJSONFilter!, $archived: Boolean, $cachedKeyIds: [LrRelayIdInput!])
|
|
84
|
-
{
|
|
85
|
-
vaults: rootDirectories(plainMeta: $vaultFilter) {
|
|
86
|
-
edges {
|
|
87
|
-
node {
|
|
88
|
-
childDirectoryLinks(plainMeta: $categoryFilter, orderBy: "created", archived: $archived) {
|
|
89
|
-
edges {
|
|
90
|
-
node {
|
|
91
|
-
childDirectory {
|
|
92
|
-
${CategoryFields}
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
|
-
keyGraph(cachedKeyIds: $cachedKeyIds) {
|
|
101
|
-
...KeyGraphFragment
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
${KeyGraphFragment}
|
|
105
|
-
`;
|
|
106
|
-
export const GetVaultsQuery = gql `
|
|
107
|
-
query GetVaults($plainMetaFilter: LrJSONFilter!, $cachedKeyIds: [LrRelayIdInput!])
|
|
108
|
-
{
|
|
109
|
-
list: rootDirectories(plainMeta: $plainMetaFilter, orderBy: "created") {
|
|
110
|
-
edges {
|
|
111
|
-
node {
|
|
112
|
-
${VaultFields}
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
}
|
|
116
|
-
keyGraph(cachedKeyIds: $cachedKeyIds) {
|
|
117
|
-
...KeyGraphFragment
|
|
118
|
-
}
|
|
119
|
-
}
|
|
120
|
-
${KeyGraphFragment}
|
|
121
|
-
`;
|
|
122
|
-
export const GetTrustedPartyCategoriesQuery = gql `
|
|
123
|
-
query GetTrustedPartyCategoriesQuery($trustedPartyId: LrRelayIdInput!, $categoryFilter: LrJSONFilter!, $recordFilter: LrJSONFilter!, $contentFilter: LrJSONFilter, $cachedKeyIds: [LrRelayIdInput!])
|
|
124
|
-
{
|
|
125
|
-
tp(id: $trustedPartyId) {
|
|
126
|
-
sharedItems {
|
|
127
|
-
list: directories(plainMeta: $categoryFilter, orderBy: "created") {
|
|
128
|
-
edges {
|
|
129
|
-
node {
|
|
130
|
-
${CategoryFields}
|
|
131
|
-
}
|
|
132
|
-
}
|
|
133
|
-
}
|
|
134
|
-
records: directories(plainMeta: $recordFilter, orderBy: "created") {
|
|
135
|
-
edges {
|
|
136
|
-
node {
|
|
137
|
-
id
|
|
138
|
-
keyId
|
|
139
|
-
archived
|
|
140
|
-
plainMeta
|
|
141
|
-
cipherMeta
|
|
142
|
-
created
|
|
143
|
-
modified
|
|
144
|
-
${AccessFields}
|
|
145
|
-
content: childFileLinks(plainMeta: $contentFilter) {
|
|
146
|
-
edges {
|
|
147
|
-
node {
|
|
148
|
-
childFile {
|
|
149
|
-
id
|
|
150
|
-
archived
|
|
151
|
-
currentVersion {
|
|
152
|
-
state {
|
|
153
|
-
keyId
|
|
154
|
-
plainMeta
|
|
155
|
-
cipherMeta
|
|
156
|
-
created
|
|
157
|
-
modified
|
|
158
|
-
}
|
|
159
|
-
}
|
|
160
|
-
}
|
|
161
|
-
}
|
|
162
|
-
}
|
|
163
|
-
}
|
|
164
|
-
}
|
|
165
|
-
}
|
|
166
|
-
}
|
|
167
|
-
}
|
|
168
|
-
}
|
|
169
|
-
keyGraph(cachedKeyIds: $cachedKeyIds) {
|
|
170
|
-
...KeyGraphFragment
|
|
171
|
-
}
|
|
172
|
-
}
|
|
173
|
-
${KeyGraphFragment}
|
|
174
|
-
`;
|
|
175
|
-
export const GetMySharedCategoriesQuery = gql `
|
|
176
|
-
query GetMySharedCategoriesQuery($trustedPartyId: LrRelayIdInput!, $categoryFilter: LrJSONFilter!, $recordFilter: LrJSONFilter!, $contentFilter: LrJSONFilter, $cachedKeyIds: [LrRelayIdInput!])
|
|
177
|
-
{
|
|
178
|
-
tp(id: $trustedPartyId) {
|
|
179
|
-
myItems {
|
|
180
|
-
list: directories(plainMeta: $categoryFilter, orderBy: "created") {
|
|
181
|
-
edges {
|
|
182
|
-
node {
|
|
183
|
-
${CategoryFields}
|
|
184
|
-
}
|
|
185
|
-
}
|
|
186
|
-
}
|
|
187
|
-
records: directories(plainMeta: $recordFilter, orderBy: "created") {
|
|
188
|
-
edges {
|
|
189
|
-
node {
|
|
190
|
-
id
|
|
191
|
-
keyId
|
|
192
|
-
archived
|
|
193
|
-
plainMeta
|
|
194
|
-
cipherMeta
|
|
195
|
-
created
|
|
196
|
-
modified
|
|
197
|
-
${AccessFields}
|
|
198
|
-
content: childFileLinks(plainMeta: $contentFilter) {
|
|
199
|
-
edges {
|
|
200
|
-
node {
|
|
201
|
-
childFile {
|
|
202
|
-
id
|
|
203
|
-
archived
|
|
204
|
-
currentVersion {
|
|
205
|
-
state {
|
|
206
|
-
keyId
|
|
207
|
-
plainMeta
|
|
208
|
-
cipherMeta
|
|
209
|
-
created
|
|
210
|
-
modified
|
|
211
|
-
}
|
|
212
|
-
}
|
|
213
|
-
}
|
|
214
|
-
}
|
|
215
|
-
}
|
|
216
|
-
}
|
|
217
|
-
}
|
|
218
|
-
}
|
|
219
|
-
}
|
|
220
|
-
}
|
|
221
|
-
}
|
|
222
|
-
keyGraph(cachedKeyIds: $cachedKeyIds) {
|
|
223
|
-
...KeyGraphFragment
|
|
224
|
-
}
|
|
225
|
-
}
|
|
226
|
-
${KeyGraphFragment}
|
|
227
|
-
`;
|
|
228
|
-
export const parentCategoriesField = (depth = DEFAULT_BREADCRUMB_DEPTH) => {
|
|
229
|
-
if (!depth) {
|
|
230
|
-
return '';
|
|
231
|
-
}
|
|
232
|
-
return `
|
|
233
|
-
parentCategories: parentDirectoryLinks(plainMeta: $categoryFilter) {
|
|
234
|
-
edges {
|
|
235
|
-
node {
|
|
236
|
-
parentDirectory {
|
|
237
|
-
id
|
|
238
|
-
keyId
|
|
239
|
-
archived
|
|
240
|
-
plainMeta
|
|
241
|
-
cipherMeta
|
|
242
|
-
${parentCategoriesField(depth - 1)}
|
|
243
|
-
${AccessFields}
|
|
244
|
-
}
|
|
245
|
-
}
|
|
246
|
-
}
|
|
247
|
-
}
|
|
248
|
-
`;
|
|
249
|
-
};
|
|
250
|
-
export const GetCategoryQuery = (depth = DEFAULT_BREADCRUMB_DEPTH) => gql `
|
|
251
|
-
query GetCategory(
|
|
252
|
-
$id: LrRelayIdInput!,
|
|
253
|
-
$categoryFilter: LrJSONFilter!,
|
|
254
|
-
$recordFilter: LrJSONFilter!,
|
|
255
|
-
$contentFilter: LrJSONFilter,
|
|
256
|
-
$cachedKeyIds: [LrRelayIdInput!]) {
|
|
257
|
-
category: directory(id: $id) {
|
|
258
|
-
id
|
|
259
|
-
keyId
|
|
260
|
-
archived
|
|
261
|
-
plainMeta
|
|
262
|
-
cipherMeta
|
|
263
|
-
${AccessFields}
|
|
264
|
-
${descendantDirectories}
|
|
265
|
-
${parentCategoriesField(depth)}
|
|
266
|
-
subCategories: childDirectoryLinks(plainMeta: $categoryFilter, orderBy: "created") {
|
|
267
|
-
edges {
|
|
268
|
-
node {
|
|
269
|
-
childDirectory {
|
|
270
|
-
${CategoryFields}
|
|
271
|
-
}
|
|
272
|
-
}
|
|
273
|
-
}
|
|
274
|
-
}
|
|
275
|
-
records: childDirectoryLinks(plainMeta: $recordFilter, orderBy: "created") {
|
|
276
|
-
edges {
|
|
277
|
-
node {
|
|
278
|
-
childDirectory {
|
|
279
|
-
id
|
|
280
|
-
keyId
|
|
281
|
-
archived
|
|
282
|
-
plainMeta
|
|
283
|
-
cipherMeta
|
|
284
|
-
created
|
|
285
|
-
modified
|
|
286
|
-
${AccessFields}
|
|
287
|
-
content: childFileLinks(plainMeta: $contentFilter) {
|
|
288
|
-
edges {
|
|
289
|
-
node {
|
|
290
|
-
childFile {
|
|
291
|
-
id
|
|
292
|
-
archived
|
|
293
|
-
currentVersion {
|
|
294
|
-
state {
|
|
295
|
-
keyId
|
|
296
|
-
plainMeta
|
|
297
|
-
cipherMeta
|
|
298
|
-
created
|
|
299
|
-
modified
|
|
300
|
-
}
|
|
301
|
-
}
|
|
302
|
-
}
|
|
303
|
-
}
|
|
304
|
-
}
|
|
305
|
-
}
|
|
306
|
-
}
|
|
307
|
-
}
|
|
308
|
-
}
|
|
309
|
-
}
|
|
310
|
-
}
|
|
311
|
-
keyGraph(cachedKeyIds: $cachedKeyIds) {
|
|
312
|
-
...KeyGraphFragment
|
|
313
|
-
}
|
|
314
|
-
}
|
|
315
|
-
${KeyGraphFragment} `;
|
|
316
|
-
export const GetCategoryKeyIdQuery = gql `
|
|
317
|
-
query GetCategoryKeyIdQuery(
|
|
318
|
-
$id: LrRelayIdInput!
|
|
319
|
-
$cachedKeyIds: [LrRelayIdInput!]
|
|
320
|
-
) {
|
|
321
|
-
category: directory(id: $id) {
|
|
322
|
-
keyId
|
|
323
|
-
}
|
|
324
|
-
keyGraph(cachedKeyIds: $cachedKeyIds) {
|
|
325
|
-
...KeyGraphFragment
|
|
326
|
-
}
|
|
327
|
-
}
|
|
328
|
-
${KeyGraphFragment}
|
|
329
|
-
`;
|
|
330
|
-
export const CreateCategoryMutation = gql `
|
|
331
|
-
mutation CreateCategory(
|
|
332
|
-
$plainMeta: LrJSONString
|
|
333
|
-
$cipherMeta: String
|
|
334
|
-
$parentDirectories: [ParentDirectoryInput!]
|
|
335
|
-
$parentRootDirectory: ParentRootDirectoryInput
|
|
336
|
-
) {
|
|
337
|
-
new: createDirectory(
|
|
338
|
-
input: {
|
|
339
|
-
plainMeta: $plainMeta
|
|
340
|
-
cipherMeta: $cipherMeta
|
|
341
|
-
parentDirectories: $parentDirectories
|
|
342
|
-
parentRootDirectory: $parentRootDirectory
|
|
343
|
-
}
|
|
344
|
-
) {
|
|
345
|
-
category: directory {
|
|
346
|
-
id
|
|
347
|
-
keyId
|
|
348
|
-
}
|
|
349
|
-
}
|
|
350
|
-
}
|
|
351
|
-
`;
|
|
352
|
-
export const CreateVaultMutation = gql `
|
|
353
|
-
mutation CreateCategory(
|
|
354
|
-
$plainMeta: LrJSONString
|
|
355
|
-
$cipherMeta: String
|
|
356
|
-
$parentRootDirectory: ParentRootDirectoryInput
|
|
357
|
-
) {
|
|
358
|
-
new: createDirectory(
|
|
359
|
-
input: {
|
|
360
|
-
plainMeta: $plainMeta
|
|
361
|
-
cipherMeta: $cipherMeta
|
|
362
|
-
parentRootDirectory: $parentRootDirectory
|
|
363
|
-
}
|
|
364
|
-
) {
|
|
365
|
-
vault: directory {
|
|
366
|
-
id
|
|
367
|
-
keyId
|
|
368
|
-
}
|
|
369
|
-
}
|
|
370
|
-
}
|
|
371
|
-
`;
|
|
372
|
-
export const UpdateCategoryMutation = gql `
|
|
373
|
-
mutation UpdateCategory($input: UpdateDirectoryInput!) {
|
|
374
|
-
updateDirectory(input: $input) {
|
|
375
|
-
directory {
|
|
376
|
-
id
|
|
377
|
-
}
|
|
378
|
-
}
|
|
379
|
-
}
|
|
380
|
-
`;
|
|
381
|
-
export const DeleteCategoryMutation = gql `
|
|
382
|
-
mutation DeleteCategory($categoryId: LrRelayIdInput!) {
|
|
383
|
-
deleteDirectory(input: { directoryId: $categoryId }) {
|
|
384
|
-
id
|
|
385
|
-
}
|
|
386
|
-
}
|
|
387
|
-
`;
|
|
388
|
-
export const ArchiveDirectoryMutation = gql `
|
|
389
|
-
mutation ArchiveDirectory($input: ArchiveDirectoryInput!) {
|
|
390
|
-
archiveDirectory(input: $input) {
|
|
391
|
-
directory {
|
|
392
|
-
id
|
|
393
|
-
}
|
|
394
|
-
}
|
|
395
|
-
}
|
|
396
|
-
`;
|
|
397
|
-
export const UnarchiveDirectoryMutation = gql `
|
|
398
|
-
mutation UnarchiveDirectory($input: UnarchiveDirectoryInput!) {
|
|
399
|
-
unarchiveDirectory(input: $input) {
|
|
400
|
-
directory {
|
|
401
|
-
id
|
|
402
|
-
}
|
|
403
|
-
}
|
|
404
|
-
}
|
|
405
|
-
`;
|
|
406
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2F0ZWdvcnkuZ3FsLmpzIiwic291cmNlUm9vdCI6Ii9vcHQvYXRsYXNzaWFuL3BpcGVsaW5lcy9hZ2VudC9idWlsZC9wcm9qZWN0cy9jb3JlL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9jYXRlZ29yeS9jYXRlZ29yeS5ncWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDMUQsT0FBTyxHQUFHLE1BQU0sYUFBYSxDQUFDO0FBRzlCLE1BQU0sQ0FBQyxNQUFNLHdCQUF3QixHQUFHLENBQUMsQ0FBQztBQUMxQyxNQUFNLENBQUMsTUFBTSx5QkFBeUIsR0FBRyxDQUFDLENBQUM7QUFFM0MsTUFBTSxDQUFOLElBQVksYUFJWDtBQUpELFdBQVksYUFBYTtJQUN2QixnQ0FBZSxDQUFBO0lBQ2Ysc0NBQXFCLENBQUE7SUFDckIsa0NBQWlCLENBQUE7QUFDbkIsQ0FBQyxFQUpXLGFBQWEsS0FBYixhQUFhLFFBSXhCO0FBRUQsTUFBTSxDQUFDLE1BQU0sa0JBQWtCLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQztJQUMvQyxNQUFNLEVBQUU7UUFDTjtZQUNFLFFBQVEsRUFBRTtnQkFDUixhQUFhLEVBQUUsYUFBYSxDQUFDLEtBQUs7Z0JBQ2xDLE9BQU8sRUFBRSxJQUFJO2FBQ2Q7U0FDRjtLQUNGO0NBQ0YsQ0FBQyxDQUFDO0FBRUgsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUM7SUFDM0MsTUFBTSxFQUFFO1FBQ047WUFDRSxRQUFRLEVBQUU7Z0JBQ1IsYUFBYSxFQUFFLGFBQWEsQ0FBQyxRQUFRO2FBQ3RDO1NBQ0Y7S0FDRjtDQUNGLENBQUMsQ0FBQztBQUVILE1BQU0sQ0FBQyxNQUFNLFlBQVksR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDO0lBQ3pDLE1BQU0sRUFBRTtRQUNOO1lBQ0UsUUFBUSxFQUFFO2dCQUNSLGFBQWEsRUFBRSxhQUFhLENBQUMsTUFBTTthQUNwQztTQUNGO0tBQ0Y7Q0FDRixDQUFDLENBQUM7QUFFSCxNQUFNLENBQUMsTUFBTSxZQUFZLEdBQUc7Ozs7Ozs7Ozs7O0VBVzFCLENBQUM7QUFFSCxNQUFNLHFCQUFxQixHQUFHOytCQUNDLHlCQUF5Qjs7O0NBR3ZELENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxjQUFjLEdBQUc7Ozs7OztJQU0xQixZQUFZO0lBQ1oscUJBQXFCO0NBQ3hCLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxXQUFXLEdBQUc7Ozs7O0NBSzFCLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSx3QkFBd0IsR0FBRyxHQUFHLENBQUE7Ozs7Ozs7Ozs7Q0FVMUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLEdBQUcsQ0FBQTs7Ozs7Ozs7OztrQkFVbkIsY0FBYzs7Ozs7Ozs7Ozs7O0VBWTlCLGdCQUFnQjtDQUNqQixDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUFHLEdBQUcsQ0FBQTs7Ozs7O1VBTXZCLFdBQVc7Ozs7Ozs7O0VBUW5CLGdCQUFnQjtDQUNqQixDQUFDO0FBV0YsTUFBTSxDQUFDLE1BQU0sOEJBQThCLEdBQUcsR0FBRyxDQUFBOzs7Ozs7OztjQVFuQyxjQUFjOzs7Ozs7Ozs7Ozs7OztjQWNkLFlBQVk7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0VBNkJ4QixnQkFBZ0I7Q0FDakIsQ0FBQztBQVdGLE1BQU0sQ0FBQyxNQUFNLDBCQUEwQixHQUFHLEdBQUcsQ0FBQTs7Ozs7Ozs7Y0FRL0IsY0FBYzs7Ozs7Ozs7Ozs7Ozs7Y0FjZCxZQUFZOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztFQTZCeEIsZ0JBQWdCO0NBQ2pCLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxxQkFBcUIsR0FBRyxDQUFDLEtBQUssR0FBRyx3QkFBd0IsRUFBRSxFQUFFO0lBQ3hFLElBQUksQ0FBQyxLQUFLLEVBQUU7UUFDVixPQUFPLEVBQUUsQ0FBQztLQUNYO0lBQ0QsT0FBTzs7Ozs7Ozs7OztVQVVDLHFCQUFxQixDQUFDLEtBQUssR0FBRyxDQUFDLENBQUM7VUFDaEMsWUFBWTs7Ozs7Q0FLckIsQ0FBQztBQUNGLENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHLENBQzlCLFFBQWdCLHdCQUF3QixFQUN4QyxFQUFFLENBQUMsR0FBRyxDQUFBOzs7Ozs7Ozs7Ozs7O01BYUYsWUFBWTtNQUNaLHFCQUFxQjtNQUNyQixxQkFBcUIsQ0FBQyxLQUFLLENBQUM7Ozs7O2NBS3BCLGNBQWM7Ozs7Ozs7Ozs7Ozs7Ozs7Y0FnQmQsWUFBWTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7RUE2QnhCLGdCQUFnQixHQUFHLENBQUM7QUFFdEIsTUFBTSxDQUFDLE1BQU0scUJBQXFCLEdBQUcsR0FBRyxDQUFBOzs7Ozs7Ozs7Ozs7SUFZcEMsZ0JBQWdCO0NBQ25CLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxzQkFBc0IsR0FBRyxHQUFHLENBQUE7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztDQXFCeEMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLG1CQUFtQixHQUFHLEdBQUcsQ0FBQTs7Ozs7Ozs7Ozs7Ozs7Ozs7OztDQW1CckMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLHNCQUFzQixHQUFHLEdBQUcsQ0FBQTs7Ozs7Ozs7Q0FReEMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLHNCQUFzQixHQUFHLEdBQUcsQ0FBQTs7Ozs7O0NBTXhDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSx3QkFBd0IsR0FBRyxHQUFHLENBQUE7Ozs7Ozs7O0NBUTFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSwwQkFBMEIsR0FBRyxHQUFHLENBQUE7Ozs7Ozs7O0NBUTVDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBIYXNLZXlHcmFwaCB9IGZyb20gJy4vLi4vY3J5cHRvZ3JhcGh5L2NyeXB0b2dyYXBoeS50eXBlcyc7XG5pbXBvcnQgeyBLZXlHcmFwaEZyYWdtZW50IH0gZnJvbSAnLi4vX2NvbW1vbi9xdWVyaWVzLmdxbCc7XG5pbXBvcnQgZ3FsIGZyb20gJ2dyYXBocWwtdGFnJztcbmltcG9ydCB7IEhhc0tleUdyYXBoRWRnZXMsIEhhc0VkZ2VzIH0gZnJvbSAnLi4vX2NvbW1vbi90eXBlcyc7XG5cbmV4cG9ydCBjb25zdCBERUZBVUxUX0JSRUFEQ1JVTUJfREVQVEggPSA1O1xuZXhwb3J0IGNvbnN0IERFRkFVTFRfREVTQ0VOREFOVFNfREVQVEggPSA1O1xuXG5leHBvcnQgZW51bSBEaXJlY3RvcnlUeXBlIHtcbiAgVmF1bHQgPSAndmF1bHQnLFxuICBDYXRlZ29yeSA9ICdjYXRlZ29yeScsXG4gIFJlY29yZCA9ICdyZWNvcmQnLFxufVxuXG5leHBvcnQgY29uc3QgRGVmYXVsdFZhdWx0RmlsdGVyID0gSlNPTi5zdHJpbmdpZnkoe1xuICBmaWx0ZXI6IFtcbiAgICB7XG4gICAgICBjb250YWluczoge1xuICAgICAgICBkaXJlY3RvcnlUeXBlOiBEaXJlY3RvcnlUeXBlLlZhdWx0LFxuICAgICAgICBkZWZhdWx0OiB0cnVlLFxuICAgICAgfSxcbiAgICB9LFxuICBdLFxufSk7XG5cbmV4cG9ydCBjb25zdCBDYXRlZ29yeUZpbHRlciA9IEpTT04uc3RyaW5naWZ5KHtcbiAgZmlsdGVyOiBbXG4gICAge1xuICAgICAgY29udGFpbnM6IHtcbiAgICAgICAgZGlyZWN0b3J5VHlwZTogRGlyZWN0b3J5VHlwZS5DYXRlZ29yeSxcbiAgICAgIH0sXG4gICAgfSxcbiAgXSxcbn0pO1xuXG5leHBvcnQgY29uc3QgUmVjb3JkRmlsdGVyID0gSlNPTi5zdHJpbmdpZnkoe1xuICBmaWx0ZXI6IFtcbiAgICB7XG4gICAgICBjb250YWluczoge1xuICAgICAgICBkaXJlY3RvcnlUeXBlOiBEaXJlY3RvcnlUeXBlLlJlY29yZCxcbiAgICAgIH0sXG4gICAgfSxcbiAgXSxcbn0pO1xuXG5leHBvcnQgY29uc3QgQWNjZXNzRmllbGRzID0gYFxuYWNjZXNzUm9sZXMge1xuICByb2xlXG4gIG1ldGhvZFxuICBpbmhlcml0ZWRGcm9tIHtcbiAgICBpZFxuICB9XG4gIHRydXN0ZWRQYXJ0eSB7XG4gICAgaWRcbiAgfVxuICBpc0lzc3VlclxufWA7XG5cbmNvbnN0IGRlc2NlbmRhbnREaXJlY3RvcmllcyA9IGBcbmRlc2NlbmRhbnREaXJlY3RvcmllcyhkZXB0aDogJHtERUZBVUxUX0RFU0NFTkRBTlRTX0RFUFRIfSwgcGxhaW5NZXRhOiAkY2F0ZWdvcnlGaWx0ZXIsIGFyY2hpdmVkOiBmYWxzZSkge1xuICByZWNvcmRzQ291bnQ6IGRpcmVjdG9yaWVzQ291bnQocGxhaW5NZXRhOiAkcmVjb3JkRmlsdGVyLCBhcmNoaXZlZDogZmFsc2UpXG59XG5gO1xuXG5leHBvcnQgY29uc3QgQ2F0ZWdvcnlGaWVsZHMgPSBgXG4gIGlkXG4gIGtleUlkXG4gIGFyY2hpdmVkXG4gIHBsYWluTWV0YVxuICBjaXBoZXJNZXRhXG4gICR7QWNjZXNzRmllbGRzfVxuICAke2Rlc2NlbmRhbnREaXJlY3Rvcmllc31cbmA7XG5cbmV4cG9ydCBjb25zdCBWYXVsdEZpZWxkcyA9IGBcbiAgaWRcbiAga2V5SWRcbiAgcGxhaW5NZXRhXG4gIGNpcGhlck1ldGFcbmA7XG5cbmV4cG9ydCBjb25zdCBHZXRSb290RGlyZWN0b3J5SWRzUXVlcnkgPSBncWxgXG4gIHF1ZXJ5IEdldFJvb3REaXJlY3RvcnlJZHNRdWVyeSgkYXJjaGl2ZWQ6IEJvb2xlYW4pIHtcbiAgICByb290RGlyZWN0b3JpZXMoYXJjaGl2ZWQ6ICRhcmNoaXZlZCkge1xuICAgICAgZWRnZXMge1xuICAgICAgICBub2RlIHtcbiAgICAgICAgICBpZFxuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgR2V0Q2F0ZWdvcmllc1F1ZXJ5ID0gZ3FsYFxucXVlcnkgR2V0Q2F0ZWdvcmllcygkdmF1bHRGaWx0ZXI6IExySlNPTkZpbHRlciEsICRjYXRlZ29yeUZpbHRlcjogTHJKU09ORmlsdGVyISwgJHJlY29yZEZpbHRlcjogTHJKU09ORmlsdGVyISwgJGFyY2hpdmVkOiBCb29sZWFuLCAkY2FjaGVkS2V5SWRzOiBbTHJSZWxheUlkSW5wdXQhXSlcbntcbiAgdmF1bHRzOiByb290RGlyZWN0b3JpZXMocGxhaW5NZXRhOiAkdmF1bHRGaWx0ZXIpIHtcbiAgICBlZGdlcyB7XG4gICAgICBub2RlIHtcbiAgICAgICAgY2hpbGREaXJlY3RvcnlMaW5rcyhwbGFpbk1ldGE6ICRjYXRlZ29yeUZpbHRlciwgb3JkZXJCeTogXCJjcmVhdGVkXCIsIGFyY2hpdmVkOiAkYXJjaGl2ZWQpIHtcbiAgICAgICAgICBlZGdlcyB7XG4gICAgICAgICAgICBub2RlIHtcbiAgICAgICAgICAgICAgY2hpbGREaXJlY3Rvcnkge1xuICAgICAgICAgICAgICAgICR7Q2F0ZWdvcnlGaWVsZHN9XG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG4gIH1cbiAga2V5R3JhcGgoY2FjaGVkS2V5SWRzOiAkY2FjaGVkS2V5SWRzKSB7XG4gICAgLi4uS2V5R3JhcGhGcmFnbWVudFxuICB9XG59XG4ke0tleUdyYXBoRnJhZ21lbnR9XG5gO1xuXG5leHBvcnQgY29uc3QgR2V0VmF1bHRzUXVlcnkgPSBncWxgXG5xdWVyeSBHZXRWYXVsdHMoJHBsYWluTWV0YUZpbHRlcjogTHJKU09ORmlsdGVyISwgJGNhY2hlZEtleUlkczogW0xyUmVsYXlJZElucHV0IV0pXG57XG4gIGxpc3Q6IHJvb3REaXJlY3RvcmllcyhwbGFpbk1ldGE6ICRwbGFpbk1ldGFGaWx0ZXIsIG9yZGVyQnk6IFwiY3JlYXRlZFwiKSB7XG4gICAgZWRnZXMge1xuICAgICAgbm9kZSB7XG4gICAgICAgICR7VmF1bHRGaWVsZHN9XG4gICAgICB9XG4gICAgfVxuICB9XG4gIGtleUdyYXBoKGNhY2hlZEtleUlkczogJGNhY2hlZEtleUlkcykge1xuICAgIC4uLktleUdyYXBoRnJhZ21lbnRcbiAgfVxufVxuJHtLZXlHcmFwaEZyYWdtZW50fVxuYDtcblxuZXhwb3J0IGludGVyZmFjZSBHZXRUcnVzdGVkUGFydHlDYXRlZ29yaWVzUXVlcnlUeXBlIGV4dGVuZHMgSGFzS2V5R3JhcGgge1xuICB0cDoge1xuICAgIHNoYXJlZEl0ZW1zOiB7XG4gICAgICBsaXN0OiBIYXNFZGdlczxhbnk+O1xuICAgICAgcmVjb3JkczogSGFzRWRnZXM8YW55PjtcbiAgICB9O1xuICB9O1xufVxuXG5leHBvcnQgY29uc3QgR2V0VHJ1c3RlZFBhcnR5Q2F0ZWdvcmllc1F1ZXJ5ID0gZ3FsYFxucXVlcnkgR2V0VHJ1c3RlZFBhcnR5Q2F0ZWdvcmllc1F1ZXJ5KCR0cnVzdGVkUGFydHlJZDogTHJSZWxheUlkSW5wdXQhLCAkY2F0ZWdvcnlGaWx0ZXI6IExySlNPTkZpbHRlciEsICRyZWNvcmRGaWx0ZXI6IExySlNPTkZpbHRlciEsICRjb250ZW50RmlsdGVyOiBMckpTT05GaWx0ZXIsICRjYWNoZWRLZXlJZHM6IFtMclJlbGF5SWRJbnB1dCFdKVxue1xuICB0cChpZDogJHRydXN0ZWRQYXJ0eUlkKSB7XG4gICAgc2hhcmVkSXRlbXMge1xuICAgICAgbGlzdDogZGlyZWN0b3JpZXMocGxhaW5NZXRhOiAkY2F0ZWdvcnlGaWx0ZXIsIG9yZGVyQnk6IFwiY3JlYXRlZFwiKSB7XG4gICAgICAgIGVkZ2VzIHtcbiAgICAgICAgICBub2RlIHtcbiAgICAgICAgICAgICR7Q2F0ZWdvcnlGaWVsZHN9XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG4gICAgICByZWNvcmRzOiBkaXJlY3RvcmllcyhwbGFpbk1ldGE6ICRyZWNvcmRGaWx0ZXIsIG9yZGVyQnk6IFwiY3JlYXRlZFwiKSB7XG4gICAgICAgIGVkZ2VzIHtcbiAgICAgICAgICBub2RlIHtcbiAgICAgICAgICAgIGlkXG4gICAgICAgICAgICBrZXlJZFxuICAgICAgICAgICAgYXJjaGl2ZWRcbiAgICAgICAgICAgIHBsYWluTWV0YVxuICAgICAgICAgICAgY2lwaGVyTWV0YVxuICAgICAgICAgICAgY3JlYXRlZFxuICAgICAgICAgICAgbW9kaWZpZWRcbiAgICAgICAgICAgICR7QWNjZXNzRmllbGRzfVxuICAgICAgICAgICAgY29udGVudDogY2hpbGRGaWxlTGlua3MocGxhaW5NZXRhOiAkY29udGVudEZpbHRlcikge1xuICAgICAgICAgICAgICBlZGdlcyB7XG4gICAgICAgICAgICAgICAgbm9kZSB7XG4gICAgICAgICAgICAgICAgICBjaGlsZEZpbGUge1xuICAgICAgICAgICAgICAgICAgICBpZFxuICAgICAgICAgICAgICAgICAgICBhcmNoaXZlZFxuICAgICAgICAgICAgICAgICAgICBjdXJyZW50VmVyc2lvbiB7XG4gICAgICAgICAgICAgICAgICAgICAgc3RhdGUge1xuICAgICAgICAgICAgICAgICAgICAgICAga2V5SWRcbiAgICAgICAgICAgICAgICAgICAgICAgIHBsYWluTWV0YVxuICAgICAgICAgICAgICAgICAgICAgICAgY2lwaGVyTWV0YVxuICAgICAgICAgICAgICAgICAgICAgICAgY3JlYXRlZFxuICAgICAgICAgICAgICAgICAgICAgICAgbW9kaWZpZWRcbiAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG4gIH1cbiAga2V5R3JhcGgoY2FjaGVkS2V5SWRzOiAkY2FjaGVkS2V5SWRzKSB7XG4gICAgLi4uS2V5R3JhcGhGcmFnbWVudFxuICB9XG59XG4ke0tleUdyYXBoRnJhZ21lbnR9XG5gO1xuXG5leHBvcnQgaW50ZXJmYWNlIEdldE15U2hhcmVkQ2F0ZWdvcmllc1F1ZXJ5VHlwZSBleHRlbmRzIEhhc0tleUdyYXBoIHtcbiAgdHA6IHtcbiAgICBteUl0ZW1zOiB7XG4gICAgICBsaXN0OiBIYXNFZGdlczxhbnk+O1xuICAgICAgcmVjb3JkczogSGFzRWRnZXM8YW55PjtcbiAgICB9O1xuICB9O1xufVxuXG5leHBvcnQgY29uc3QgR2V0TXlTaGFyZWRDYXRlZ29yaWVzUXVlcnkgPSBncWxgXG5xdWVyeSBHZXRNeVNoYXJlZENhdGVnb3JpZXNRdWVyeSgkdHJ1c3RlZFBhcnR5SWQ6IExyUmVsYXlJZElucHV0ISwgJGNhdGVnb3J5RmlsdGVyOiBMckpTT05GaWx0ZXIhLCAkcmVjb3JkRmlsdGVyOiBMckpTT05GaWx0ZXIhLCAkY29udGVudEZpbHRlcjogTHJKU09ORmlsdGVyLCAkY2FjaGVkS2V5SWRzOiBbTHJSZWxheUlkSW5wdXQhXSlcbntcbiAgdHAoaWQ6ICR0cnVzdGVkUGFydHlJZCkge1xuICAgIG15SXRlbXMge1xuICAgICAgbGlzdDogZGlyZWN0b3JpZXMocGxhaW5NZXRhOiAkY2F0ZWdvcnlGaWx0ZXIsIG9yZGVyQnk6IFwiY3JlYXRlZFwiKSB7XG4gICAgICAgIGVkZ2VzIHtcbiAgICAgICAgICBub2RlIHtcbiAgICAgICAgICAgICR7Q2F0ZWdvcnlGaWVsZHN9XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG4gICAgICByZWNvcmRzOiBkaXJlY3RvcmllcyhwbGFpbk1ldGE6ICRyZWNvcmRGaWx0ZXIsIG9yZGVyQnk6IFwiY3JlYXRlZFwiKSB7XG4gICAgICAgIGVkZ2VzIHtcbiAgICAgICAgICBub2RlIHtcbiAgICAgICAgICAgIGlkXG4gICAgICAgICAgICBrZXlJZFxuICAgICAgICAgICAgYXJjaGl2ZWRcbiAgICAgICAgICAgIHBsYWluTWV0YVxuICAgICAgICAgICAgY2lwaGVyTWV0YVxuICAgICAgICAgICAgY3JlYXRlZFxuICAgICAgICAgICAgbW9kaWZpZWRcbiAgICAgICAgICAgICR7QWNjZXNzRmllbGRzfVxuICAgICAgICAgICAgY29udGVudDogY2hpbGRGaWxlTGlua3MocGxhaW5NZXRhOiAkY29udGVudEZpbHRlcikge1xuICAgICAgICAgICAgICBlZGdlcyB7XG4gICAgICAgICAgICAgICAgbm9kZSB7XG4gICAgICAgICAgICAgICAgICBjaGlsZEZpbGUge1xuICAgICAgICAgICAgICAgICAgICBpZFxuICAgICAgICAgICAgICAgICAgICBhcmNoaXZlZFxuICAgICAgICAgICAgICAgICAgICBjdXJyZW50VmVyc2lvbiB7XG4gICAgICAgICAgICAgICAgICAgICAgc3RhdGUge1xuICAgICAgICAgICAgICAgICAgICAgICAga2V5SWRcbiAgICAgICAgICAgICAgICAgICAgICAgIHBsYWluTWV0YVxuICAgICAgICAgICAgICAgICAgICAgICAgY2lwaGVyTWV0YVxuICAgICAgICAgICAgICAgICAgICAgICAgY3JlYXRlZFxuICAgICAgICAgICAgICAgICAgICAgICAgbW9kaWZpZWRcbiAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG4gIH1cbiAga2V5R3JhcGgoY2FjaGVkS2V5SWRzOiAkY2FjaGVkS2V5SWRzKSB7XG4gICAgLi4uS2V5R3JhcGhGcmFnbWVudFxuICB9XG59XG4ke0tleUdyYXBoRnJhZ21lbnR9XG5gO1xuXG5leHBvcnQgY29uc3QgcGFyZW50Q2F0ZWdvcmllc0ZpZWxkID0gKGRlcHRoID0gREVGQVVMVF9CUkVBRENSVU1CX0RFUFRIKSA9PiB7XG4gIGlmICghZGVwdGgpIHtcbiAgICByZXR1cm4gJyc7XG4gIH1cbiAgcmV0dXJuIGBcbnBhcmVudENhdGVnb3JpZXM6IHBhcmVudERpcmVjdG9yeUxpbmtzKHBsYWluTWV0YTogJGNhdGVnb3J5RmlsdGVyKSB7XG4gIGVkZ2VzIHtcbiAgICBub2RlIHtcbiAgICAgIHBhcmVudERpcmVjdG9yeSB7XG4gICAgICAgIGlkXG4gICAgICAgIGtleUlkXG4gICAgICAgIGFyY2hpdmVkXG4gICAgICAgIHBsYWluTWV0YVxuICAgICAgICBjaXBoZXJNZXRhXG4gICAgICAgICR7cGFyZW50Q2F0ZWdvcmllc0ZpZWxkKGRlcHRoIC0gMSl9XG4gICAgICAgICR7QWNjZXNzRmllbGRzfVxuICAgICAgfVxuICAgIH1cbiAgfVxufVxuYDtcbn07XG5cbmV4cG9ydCBjb25zdCBHZXRDYXRlZ29yeVF1ZXJ5ID0gKFxuICBkZXB0aDogbnVtYmVyID0gREVGQVVMVF9CUkVBRENSVU1CX0RFUFRIXG4pID0+IGdxbGBcbnF1ZXJ5IEdldENhdGVnb3J5KFxuICAkaWQ6IExyUmVsYXlJZElucHV0ISxcbiAgJGNhdGVnb3J5RmlsdGVyOiBMckpTT05GaWx0ZXIhLFxuICAkcmVjb3JkRmlsdGVyOiBMckpTT05GaWx0ZXIhLFxuICAkY29udGVudEZpbHRlcjogTHJKU09ORmlsdGVyLFxuICAkY2FjaGVkS2V5SWRzOiBbTHJSZWxheUlkSW5wdXQhXSkge1xuICBjYXRlZ29yeTogZGlyZWN0b3J5KGlkOiAkaWQpIHtcbiAgICBpZFxuICAgIGtleUlkXG4gICAgYXJjaGl2ZWRcbiAgICBwbGFpbk1ldGFcbiAgICBjaXBoZXJNZXRhXG4gICAgJHtBY2Nlc3NGaWVsZHN9XG4gICAgJHtkZXNjZW5kYW50RGlyZWN0b3JpZXN9XG4gICAgJHtwYXJlbnRDYXRlZ29yaWVzRmllbGQoZGVwdGgpfVxuICAgIHN1YkNhdGVnb3JpZXM6IGNoaWxkRGlyZWN0b3J5TGlua3MocGxhaW5NZXRhOiAkY2F0ZWdvcnlGaWx0ZXIsIG9yZGVyQnk6IFwiY3JlYXRlZFwiKSB7XG4gICAgICBlZGdlcyB7XG4gICAgICAgIG5vZGUge1xuICAgICAgICAgIGNoaWxkRGlyZWN0b3J5IHtcbiAgICAgICAgICAgICR7Q2F0ZWdvcnlGaWVsZHN9XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuICAgIHJlY29yZHM6IGNoaWxkRGlyZWN0b3J5TGlua3MocGxhaW5NZXRhOiAkcmVjb3JkRmlsdGVyLCBvcmRlckJ5OiBcImNyZWF0ZWRcIikge1xuICAgICAgZWRnZXMge1xuICAgICAgICBub2RlIHtcbiAgICAgICAgICBjaGlsZERpcmVjdG9yeSB7XG4gICAgICAgICAgICBpZFxuICAgICAgICAgICAga2V5SWRcbiAgICAgICAgICAgIGFyY2hpdmVkXG4gICAgICAgICAgICBwbGFpbk1ldGFcbiAgICAgICAgICAgIGNpcGhlck1ldGFcbiAgICAgICAgICAgIGNyZWF0ZWRcbiAgICAgICAgICAgIG1vZGlmaWVkXG4gICAgICAgICAgICAke0FjY2Vzc0ZpZWxkc31cbiAgICAgICAgICAgIGNvbnRlbnQ6IGNoaWxkRmlsZUxpbmtzKHBsYWluTWV0YTogJGNvbnRlbnRGaWx0ZXIpIHtcbiAgICAgICAgICAgICAgZWRnZXMge1xuICAgICAgICAgICAgICAgIG5vZGUge1xuICAgICAgICAgICAgICAgICAgY2hpbGRGaWxlIHtcbiAgICAgICAgICAgICAgICAgICAgaWRcbiAgICAgICAgICAgICAgICAgICAgYXJjaGl2ZWRcbiAgICAgICAgICAgICAgICAgICAgY3VycmVudFZlcnNpb24ge1xuICAgICAgICAgICAgICAgICAgICAgIHN0YXRlIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIGtleUlkXG4gICAgICAgICAgICAgICAgICAgICAgICBwbGFpbk1ldGFcbiAgICAgICAgICAgICAgICAgICAgICAgIGNpcGhlck1ldGFcbiAgICAgICAgICAgICAgICAgICAgICAgIGNyZWF0ZWRcbiAgICAgICAgICAgICAgICAgICAgICAgIG1vZGlmaWVkXG4gICAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuICB9XG4gIGtleUdyYXBoKGNhY2hlZEtleUlkczogJGNhY2hlZEtleUlkcykge1xuICAgIC4uLktleUdyYXBoRnJhZ21lbnRcbiAgfVxufVxuJHtLZXlHcmFwaEZyYWdtZW50fSBgO1xuXG5leHBvcnQgY29uc3QgR2V0Q2F0ZWdvcnlLZXlJZFF1ZXJ5ID0gZ3FsYFxuICBxdWVyeSBHZXRDYXRlZ29yeUtleUlkUXVlcnkoXG4gICAgJGlkOiBMclJlbGF5SWRJbnB1dCFcbiAgICAkY2FjaGVkS2V5SWRzOiBbTHJSZWxheUlkSW5wdXQhXVxuICApIHtcbiAgICBjYXRlZ29yeTogZGlyZWN0b3J5KGlkOiAkaWQpIHtcbiAgICAgIGtleUlkXG4gICAgfVxuICAgIGtleUdyYXBoKGNhY2hlZEtleUlkczogJGNhY2hlZEtleUlkcykge1xuICAgICAgLi4uS2V5R3JhcGhGcmFnbWVudFxuICAgIH1cbiAgfVxuICAke0tleUdyYXBoRnJhZ21lbnR9XG5gO1xuXG5leHBvcnQgY29uc3QgQ3JlYXRlQ2F0ZWdvcnlNdXRhdGlvbiA9IGdxbGBcbiAgbXV0YXRpb24gQ3JlYXRlQ2F0ZWdvcnkoXG4gICAgJHBsYWluTWV0YTogTHJKU09OU3RyaW5nXG4gICAgJGNpcGhlck1ldGE6IFN0cmluZ1xuICAgICRwYXJlbnREaXJlY3RvcmllczogW1BhcmVudERpcmVjdG9yeUlucHV0IV1cbiAgICAkcGFyZW50Um9vdERpcmVjdG9yeTogUGFyZW50Um9vdERpcmVjdG9yeUlucHV0XG4gICkge1xuICAgIG5ldzogY3JlYXRlRGlyZWN0b3J5KFxuICAgICAgaW5wdXQ6IHtcbiAgICAgICAgcGxhaW5NZXRhOiAkcGxhaW5NZXRhXG4gICAgICAgIGNpcGhlck1ldGE6ICRjaXBoZXJNZXRhXG4gICAgICAgIHBhcmVudERpcmVjdG9yaWVzOiAkcGFyZW50RGlyZWN0b3JpZXNcbiAgICAgICAgcGFyZW50Um9vdERpcmVjdG9yeTogJHBhcmVudFJvb3REaXJlY3RvcnlcbiAgICAgIH1cbiAgICApIHtcbiAgICAgIGNhdGVnb3J5OiBkaXJlY3Rvcnkge1xuICAgICAgICBpZFxuICAgICAgICBrZXlJZFxuICAgICAgfVxuICAgIH1cbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IENyZWF0ZVZhdWx0TXV0YXRpb24gPSBncWxgXG4gIG11dGF0aW9uIENyZWF0ZUNhdGVnb3J5KFxuICAgICRwbGFpbk1ldGE6IExySlNPTlN0cmluZ1xuICAgICRjaXBoZXJNZXRhOiBTdHJpbmdcbiAgICAkcGFyZW50Um9vdERpcmVjdG9yeTogUGFyZW50Um9vdERpcmVjdG9yeUlucHV0XG4gICkge1xuICAgIG5ldzogY3JlYXRlRGlyZWN0b3J5KFxuICAgICAgaW5wdXQ6IHtcbiAgICAgICAgcGxhaW5NZXRhOiAkcGxhaW5NZXRhXG4gICAgICAgIGNpcGhlck1ldGE6ICRjaXBoZXJNZXRhXG4gICAgICAgIHBhcmVudFJvb3REaXJlY3Rvcnk6ICRwYXJlbnRSb290RGlyZWN0b3J5XG4gICAgICB9XG4gICAgKSB7XG4gICAgICB2YXVsdDogZGlyZWN0b3J5IHtcbiAgICAgICAgaWRcbiAgICAgICAga2V5SWRcbiAgICAgIH1cbiAgICB9XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBVcGRhdGVDYXRlZ29yeU11dGF0aW9uID0gZ3FsYFxuICBtdXRhdGlvbiBVcGRhdGVDYXRlZ29yeSgkaW5wdXQ6IFVwZGF0ZURpcmVjdG9yeUlucHV0ISkge1xuICAgIHVwZGF0ZURpcmVjdG9yeShpbnB1dDogJGlucHV0KSB7XG4gICAgICBkaXJlY3Rvcnkge1xuICAgICAgICBpZFxuICAgICAgfVxuICAgIH1cbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IERlbGV0ZUNhdGVnb3J5TXV0YXRpb24gPSBncWxgXG4gIG11dGF0aW9uIERlbGV0ZUNhdGVnb3J5KCRjYXRlZ29yeUlkOiBMclJlbGF5SWRJbnB1dCEpIHtcbiAgICBkZWxldGVEaXJlY3RvcnkoaW5wdXQ6IHsgZGlyZWN0b3J5SWQ6ICRjYXRlZ29yeUlkIH0pIHtcbiAgICAgIGlkXG4gICAgfVxuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgQXJjaGl2ZURpcmVjdG9yeU11dGF0aW9uID0gZ3FsYFxuICBtdXRhdGlvbiBBcmNoaXZlRGlyZWN0b3J5KCRpbnB1dDogQXJjaGl2ZURpcmVjdG9yeUlucHV0ISkge1xuICAgIGFyY2hpdmVEaXJlY3RvcnkoaW5wdXQ6ICRpbnB1dCkge1xuICAgICAgZGlyZWN0b3J5IHtcbiAgICAgICAgaWRcbiAgICAgIH1cbiAgICB9XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBVbmFyY2hpdmVEaXJlY3RvcnlNdXRhdGlvbiA9IGdxbGBcbiAgbXV0YXRpb24gVW5hcmNoaXZlRGlyZWN0b3J5KCRpbnB1dDogVW5hcmNoaXZlRGlyZWN0b3J5SW5wdXQhKSB7XG4gICAgdW5hcmNoaXZlRGlyZWN0b3J5KGlucHV0OiAkaW5wdXQpIHtcbiAgICAgIGRpcmVjdG9yeSB7XG4gICAgICAgIGlkXG4gICAgICB9XG4gICAgfVxuICB9XG5gO1xuIl19
|