@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,40 @@
|
|
|
1
|
+
import { gqlTyped } from '../_common/ast';
|
|
2
|
+
export const LockFragment = gqlTyped `
|
|
3
|
+
fragment LockFragment on LockField {
|
|
4
|
+
created
|
|
5
|
+
modified
|
|
6
|
+
version
|
|
7
|
+
expiryTime
|
|
8
|
+
state
|
|
9
|
+
}`;
|
|
10
|
+
export const UpdateLockMutation = gqlTyped `
|
|
11
|
+
mutation UpdateLockMutation($input: UpdateLockInput!) {
|
|
12
|
+
updateLock(input: $input) {
|
|
13
|
+
lock {
|
|
14
|
+
...LockFragment
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
${LockFragment}
|
|
19
|
+
`;
|
|
20
|
+
export const AcquireLockMutation = gqlTyped `
|
|
21
|
+
mutation AcquireLockMutation($input: AcquireLockInput!) {
|
|
22
|
+
acquireLock(input: $input) {
|
|
23
|
+
lock {
|
|
24
|
+
...LockFragment
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
${LockFragment}
|
|
29
|
+
`;
|
|
30
|
+
export const ReleaseLockMutation = gqlTyped `
|
|
31
|
+
mutation ReleaseLockMutation($input: ReleaseLockInput!) {
|
|
32
|
+
releaseLock(input: $input) {
|
|
33
|
+
lock {
|
|
34
|
+
...LockFragment
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
${LockFragment}
|
|
39
|
+
`;
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9jay5ncWwuanMiLCJzb3VyY2VSb290IjoiQzovUHJvamVjdHMvbmV3cmVwby9rYy1jbGllbnQvcHJvamVjdHMvY29yZS9zcmMvIiwic291cmNlcyI6WyJsaWIvYXBpL2xvY2suZ3FsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQVUxQyxNQUFNLENBQUMsTUFBTSxZQUFZLEdBQUcsUUFBUSxDQUFvQjs7Ozs7OztFQU90RCxDQUFDO0FBT0gsTUFBTSxDQUFDLE1BQU0sa0JBQWtCLEdBQUcsUUFBUSxDQUEwQjs7Ozs7Ozs7RUFRbEUsWUFBWTtDQUNiLENBQUM7QUFPRixNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FBRyxRQUFRLENBQTJCOzs7Ozs7OztFQVFwRSxZQUFZO0NBQ2IsQ0FBQztBQU9GLE1BQU0sQ0FBQyxNQUFNLG1CQUFtQixHQUFHLFFBQVEsQ0FBMkI7Ozs7Ozs7O0VBUXBFLFlBQVk7Q0FDYixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSldLIH0gZnJvbSAnbm9kZS1qb3NlJztcclxuaW1wb3J0IHsgZ3FsVHlwZWQgfSBmcm9tICcuLi9fY29tbW9uL2FzdCc7XHJcbmltcG9ydCB7IERhdGVUaW1lLCBMb2NrU3RhdGUsIFVVSUQgfSBmcm9tICcuL3R5cGVzJztcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgTG9ja0ZyYWdtZW50UmVzdWx0IHtcclxuICBjcmVhdGVkOiBEYXRlVGltZTtcclxuICBtb2RpZmllZDogRGF0ZVRpbWU7XHJcbiAgdmVyc2lvbj86IFVVSUQ7XHJcbiAgZXhwaXJ5VGltZTogRGF0ZVRpbWU7XHJcbiAgc3RhdGU6IExvY2tTdGF0ZTtcclxufVxyXG5leHBvcnQgY29uc3QgTG9ja0ZyYWdtZW50ID0gZ3FsVHlwZWQ8TG9ja0ZyYWdtZW50UmVzdWx0PmBcclxuZnJhZ21lbnQgTG9ja0ZyYWdtZW50IG9uIExvY2tGaWVsZCB7XHJcbiAgY3JlYXRlZFxyXG4gIG1vZGlmaWVkXHJcbiAgdmVyc2lvblxyXG4gIGV4cGlyeVRpbWVcclxuICBzdGF0ZVxyXG59YDtcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgVXBkYXRlTG9ja011dGF0aW9uUmVzdWx0IHtcclxuICB1cGRhdGVMb2NrOiB7XHJcbiAgICBsb2NrOiBMb2NrRnJhZ21lbnRSZXN1bHQ7XHJcbiAgfTtcclxufVxyXG5leHBvcnQgY29uc3QgVXBkYXRlTG9ja011dGF0aW9uID0gZ3FsVHlwZWQ8VXBkYXRlTG9ja011dGF0aW9uUmVzdWx0PmBcclxubXV0YXRpb24gVXBkYXRlTG9ja011dGF0aW9uKCRpbnB1dDogVXBkYXRlTG9ja0lucHV0ISkge1xyXG4gIHVwZGF0ZUxvY2soaW5wdXQ6ICRpbnB1dCkge1xyXG4gICAgbG9jayB7XHJcbiAgICAgIC4uLkxvY2tGcmFnbWVudFxyXG4gICAgfVxyXG4gIH1cclxufVxyXG4ke0xvY2tGcmFnbWVudH1cclxuYDtcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgQWNxdWlyZUxvY2tNdXRhdGlvblJlc3VsdCB7XHJcbiAgYWNxdWlyZUxvY2s6IHtcclxuICAgIGxvY2s6IExvY2tGcmFnbWVudFJlc3VsdDtcclxuICB9O1xyXG59XHJcbmV4cG9ydCBjb25zdCBBY3F1aXJlTG9ja011dGF0aW9uID0gZ3FsVHlwZWQ8QWNxdWlyZUxvY2tNdXRhdGlvblJlc3VsdD5gXHJcbm11dGF0aW9uIEFjcXVpcmVMb2NrTXV0YXRpb24oJGlucHV0OiBBY3F1aXJlTG9ja0lucHV0ISkge1xyXG4gIGFjcXVpcmVMb2NrKGlucHV0OiAkaW5wdXQpIHtcclxuICAgIGxvY2sge1xyXG4gICAgICAuLi5Mb2NrRnJhZ21lbnRcclxuICAgIH1cclxuICB9XHJcbn1cclxuJHtMb2NrRnJhZ21lbnR9XHJcbmA7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIFJlbGVhc2VMb2NrTXV0YXRpb25SZXN1bHQge1xyXG4gIHJlbGVhc2VMb2NrOiB7XHJcbiAgICBsb2NrOiBMb2NrRnJhZ21lbnRSZXN1bHQ7XHJcbiAgfTtcclxufVxyXG5leHBvcnQgY29uc3QgUmVsZWFzZUxvY2tNdXRhdGlvbiA9IGdxbFR5cGVkPFJlbGVhc2VMb2NrTXV0YXRpb25SZXN1bHQ+YFxyXG5tdXRhdGlvbiBSZWxlYXNlTG9ja011dGF0aW9uKCRpbnB1dDogUmVsZWFzZUxvY2tJbnB1dCEpIHtcclxuICByZWxlYXNlTG9jayhpbnB1dDogJGlucHV0KSB7XHJcbiAgICBsb2NrIHtcclxuICAgICAgLi4uTG9ja0ZyYWdtZW50XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiR7TG9ja0ZyYWdtZW50fVxyXG5gO1xyXG4iXX0=
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { Injectable, Injector, NgZone } from '@angular/core';
|
|
3
|
+
import { LrMutation, LrService } from './lr-graphql';
|
|
4
|
+
import { AcquireLockMutation, ReleaseLockMutation, UpdateLockMutation, } from './lock.gql';
|
|
5
|
+
import { RunOutsideAngular } from '../_common/run-outside-angular';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
let LockService = class LockService extends LrService {
|
|
8
|
+
constructor(ngZone, injector) {
|
|
9
|
+
super(injector);
|
|
10
|
+
this.ngZone = ngZone;
|
|
11
|
+
this.injector = injector;
|
|
12
|
+
}
|
|
13
|
+
// Updating the lock version is always to be down along with another mutation.
|
|
14
|
+
updateLockMutation(resourceId, version) {
|
|
15
|
+
return new LrMutation({
|
|
16
|
+
mutation: UpdateLockMutation,
|
|
17
|
+
variables: {
|
|
18
|
+
input: {
|
|
19
|
+
resourceId,
|
|
20
|
+
version,
|
|
21
|
+
},
|
|
22
|
+
},
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
acquireLockMutation(resourceId, timeoutMs) {
|
|
26
|
+
return new LrMutation({
|
|
27
|
+
mutation: AcquireLockMutation,
|
|
28
|
+
variables: {
|
|
29
|
+
input: {
|
|
30
|
+
resourceId,
|
|
31
|
+
timeoutMs,
|
|
32
|
+
},
|
|
33
|
+
},
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
releaseLockMutation(resourceId, version) {
|
|
37
|
+
return new LrMutation({
|
|
38
|
+
mutation: ReleaseLockMutation,
|
|
39
|
+
variables: {
|
|
40
|
+
input: {
|
|
41
|
+
resourceId,
|
|
42
|
+
version,
|
|
43
|
+
},
|
|
44
|
+
},
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
LockService.ɵprov = i0.ɵɵdefineInjectable({ factory: function LockService_Factory() { return new LockService(i0.ɵɵinject(i0.NgZone), i0.ɵɵinject(i0.INJECTOR)); }, token: LockService, providedIn: "root" });
|
|
49
|
+
LockService.decorators = [
|
|
50
|
+
{ type: Injectable, args: [{
|
|
51
|
+
providedIn: 'root',
|
|
52
|
+
},] }
|
|
53
|
+
];
|
|
54
|
+
LockService.ctorParameters = () => [
|
|
55
|
+
{ type: NgZone },
|
|
56
|
+
{ type: Injector }
|
|
57
|
+
];
|
|
58
|
+
LockService = __decorate([
|
|
59
|
+
RunOutsideAngular({
|
|
60
|
+
ngZoneName: 'ngZone',
|
|
61
|
+
})
|
|
62
|
+
], LockService);
|
|
63
|
+
export { LockService };
|
|
64
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9jay5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IkM6L1Byb2plY3RzL25ld3JlcG8va2MtY2xpZW50L3Byb2plY3RzL2NvcmUvc3JjLyIsInNvdXJjZXMiOlsibGliL2FwaS9sb2NrLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM3RCxPQUFPLEVBQUUsVUFBVSxFQUFFLFNBQVMsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUNyRCxPQUFPLEVBQ0wsbUJBQW1CLEVBQ25CLG1CQUFtQixFQUNuQixrQkFBa0IsR0FDbkIsTUFBTSxZQUFZLENBQUM7QUFDcEIsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7O0lBUXRELFdBQVcsU0FBWCxXQUFZLFNBQVEsU0FBUztJQUN4QyxZQUFvQixNQUFjLEVBQVUsUUFBa0I7UUFDNUQsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBREUsV0FBTSxHQUFOLE1BQU0sQ0FBUTtRQUFVLGFBQVEsR0FBUixRQUFRLENBQVU7SUFFOUQsQ0FBQztJQUVELDhFQUE4RTtJQUM5RSxrQkFBa0IsQ0FBQyxVQUFrQixFQUFFLE9BQWU7UUFDcEQsT0FBTyxJQUFJLFVBQVUsQ0FBQztZQUNwQixRQUFRLEVBQUUsa0JBQWtCO1lBQzVCLFNBQVMsRUFBRTtnQkFDVCxLQUFLLEVBQUU7b0JBQ0wsVUFBVTtvQkFDVixPQUFPO2lCQUNSO2FBQ0Y7U0FDRixDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsbUJBQW1CLENBQUMsVUFBa0IsRUFBRSxTQUFpQjtRQUN2RCxPQUFPLElBQUksVUFBVSxDQUFDO1lBQ3BCLFFBQVEsRUFBRSxtQkFBbUI7WUFDN0IsU0FBUyxFQUFFO2dCQUNULEtBQUssRUFBRTtvQkFDTCxVQUFVO29CQUNWLFNBQVM7aUJBQ1Y7YUFDRjtTQUNGLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxtQkFBbUIsQ0FBQyxVQUFrQixFQUFFLE9BQWU7UUFDckQsT0FBTyxJQUFJLFVBQVUsQ0FBQztZQUNwQixRQUFRLEVBQUUsbUJBQW1CO1lBQzdCLFNBQVMsRUFBRTtnQkFDVCxLQUFLLEVBQUU7b0JBQ0wsVUFBVTtvQkFDVixPQUFPO2lCQUNSO2FBQ0Y7U0FDRixDQUFDLENBQUM7SUFDTCxDQUFDO0NBQ0YsQ0FBQTs7O1lBNUNBLFVBQVUsU0FBQztnQkFDVixVQUFVLEVBQUUsTUFBTTthQUNuQjs7O1lBZDhCLE1BQU07WUFBaEIsUUFBUTs7QUFlaEIsV0FBVztJQU52QixpQkFBaUIsQ0FBQztRQUNqQixVQUFVLEVBQUUsUUFBUTtLQUNyQixDQUFDO0dBSVcsV0FBVyxDQXlDdkI7U0F6Q1ksV0FBVyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUsIEluamVjdG9yLCBOZ1pvbmUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgTHJNdXRhdGlvbiwgTHJTZXJ2aWNlIH0gZnJvbSAnLi9sci1ncmFwaHFsJztcclxuaW1wb3J0IHtcclxuICBBY3F1aXJlTG9ja011dGF0aW9uLFxyXG4gIFJlbGVhc2VMb2NrTXV0YXRpb24sXHJcbiAgVXBkYXRlTG9ja011dGF0aW9uLFxyXG59IGZyb20gJy4vbG9jay5ncWwnO1xyXG5pbXBvcnQgeyBSdW5PdXRzaWRlQW5ndWxhciB9IGZyb20gJy4uL19jb21tb24vcnVuLW91dHNpZGUtYW5ndWxhcic7XHJcblxyXG5AUnVuT3V0c2lkZUFuZ3VsYXIoe1xyXG4gIG5nWm9uZU5hbWU6ICduZ1pvbmUnLFxyXG59KVxyXG5ASW5qZWN0YWJsZSh7XHJcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgTG9ja1NlcnZpY2UgZXh0ZW5kcyBMclNlcnZpY2Uge1xyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgbmdab25lOiBOZ1pvbmUsIHByaXZhdGUgaW5qZWN0b3I6IEluamVjdG9yKSB7XHJcbiAgICBzdXBlcihpbmplY3Rvcik7XHJcbiAgfVxyXG5cclxuICAvLyBVcGRhdGluZyB0aGUgbG9jayB2ZXJzaW9uIGlzIGFsd2F5cyB0byBiZSBkb3duIGFsb25nIHdpdGggYW5vdGhlciBtdXRhdGlvbi5cclxuICB1cGRhdGVMb2NrTXV0YXRpb24ocmVzb3VyY2VJZDogc3RyaW5nLCB2ZXJzaW9uOiBzdHJpbmcpIHtcclxuICAgIHJldHVybiBuZXcgTHJNdXRhdGlvbih7XHJcbiAgICAgIG11dGF0aW9uOiBVcGRhdGVMb2NrTXV0YXRpb24sXHJcbiAgICAgIHZhcmlhYmxlczoge1xyXG4gICAgICAgIGlucHV0OiB7XHJcbiAgICAgICAgICByZXNvdXJjZUlkLFxyXG4gICAgICAgICAgdmVyc2lvbixcclxuICAgICAgICB9LFxyXG4gICAgICB9LFxyXG4gICAgfSk7XHJcbiAgfVxyXG5cclxuICBhY3F1aXJlTG9ja011dGF0aW9uKHJlc291cmNlSWQ6IHN0cmluZywgdGltZW91dE1zOiBudW1iZXIpIHtcclxuICAgIHJldHVybiBuZXcgTHJNdXRhdGlvbih7XHJcbiAgICAgIG11dGF0aW9uOiBBY3F1aXJlTG9ja011dGF0aW9uLFxyXG4gICAgICB2YXJpYWJsZXM6IHtcclxuICAgICAgICBpbnB1dDoge1xyXG4gICAgICAgICAgcmVzb3VyY2VJZCxcclxuICAgICAgICAgIHRpbWVvdXRNcyxcclxuICAgICAgICB9LFxyXG4gICAgICB9LFxyXG4gICAgfSk7XHJcbiAgfVxyXG5cclxuICByZWxlYXNlTG9ja011dGF0aW9uKHJlc291cmNlSWQ6IHN0cmluZywgdmVyc2lvbjogc3RyaW5nKSB7XHJcbiAgICByZXR1cm4gbmV3IExyTXV0YXRpb24oe1xyXG4gICAgICBtdXRhdGlvbjogUmVsZWFzZUxvY2tNdXRhdGlvbixcclxuICAgICAgdmFyaWFibGVzOiB7XHJcbiAgICAgICAgaW5wdXQ6IHtcclxuICAgICAgICAgIHJlc291cmNlSWQsXHJcbiAgICAgICAgICB2ZXJzaW9uLFxyXG4gICAgICAgIH0sXHJcbiAgICAgIH0sXHJcbiAgICB9KTtcclxuICB9XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
2
|
+
import { Injectable } from '@angular/core';
|
|
3
|
+
import { Apollo } from 'apollo-angular';
|
|
4
|
+
import { KeyGraphService } from '../cryptography/key-graph.service';
|
|
5
|
+
import { handleApolloError } from '../_common/exceptions';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "apollo-angular";
|
|
8
|
+
import * as i2 from "../cryptography/key-graph.service";
|
|
9
|
+
export class LrApolloService {
|
|
10
|
+
constructor(apollo, keyGraph) {
|
|
11
|
+
this.apollo = apollo;
|
|
12
|
+
this.keyGraph = keyGraph;
|
|
13
|
+
}
|
|
14
|
+
addKeys(response) {
|
|
15
|
+
if (response.data.keyGraph) {
|
|
16
|
+
this.keyGraph.addKeys(response.data.keyGraph);
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
query(options) {
|
|
20
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
21
|
+
const response = yield this.apollo.query(options).toPromise();
|
|
22
|
+
handleApolloError(response.errors);
|
|
23
|
+
this.addKeys(response);
|
|
24
|
+
return response.data;
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
mutate(options) {
|
|
28
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
29
|
+
const response = yield this.apollo.mutate(options).toPromise();
|
|
30
|
+
handleApolloError(response.errors);
|
|
31
|
+
this.addKeys(response);
|
|
32
|
+
return response.data;
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
LrApolloService.ɵprov = i0.ɵɵdefineInjectable({ factory: function LrApolloService_Factory() { return new LrApolloService(i0.ɵɵinject(i1.Apollo), i0.ɵɵinject(i2.KeyGraphService)); }, token: LrApolloService, providedIn: "root" });
|
|
37
|
+
LrApolloService.decorators = [
|
|
38
|
+
{ type: Injectable, args: [{
|
|
39
|
+
providedIn: 'root',
|
|
40
|
+
},] }
|
|
41
|
+
];
|
|
42
|
+
LrApolloService.ctorParameters = () => [
|
|
43
|
+
{ type: Apollo },
|
|
44
|
+
{ type: KeyGraphService }
|
|
45
|
+
];
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibHItYXBvbGxvLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiQzovUHJvamVjdHMvbmV3cmVwby9rYy1jbGllbnQvcHJvamVjdHMvY29yZS9zcmMvIiwic291cmNlcyI6WyJsaWIvYXBpL2xyLWFwb2xsby5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNDLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUV4QyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFFcEUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7Ozs7QUFLMUQsTUFBTSxPQUFPLGVBQWU7SUFDMUIsWUFBb0IsTUFBYyxFQUFVLFFBQXlCO1FBQWpELFdBQU0sR0FBTixNQUFNLENBQVE7UUFBVSxhQUFRLEdBQVIsUUFBUSxDQUFpQjtJQUFHLENBQUM7SUFFakUsT0FBTyxDQUFDLFFBQVE7UUFDdEIsSUFBSyxRQUFRLENBQUMsSUFBb0IsQ0FBQyxRQUFRLEVBQUU7WUFDM0MsSUFBSSxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUUsUUFBUSxDQUFDLElBQW9CLENBQUMsUUFBUSxDQUFDLENBQUM7U0FDaEU7SUFDSCxDQUFDO0lBRUssS0FBSyxDQUNULE9BQXdCOztZQUV4QixNQUFNLFFBQVEsR0FBRyxNQUFNLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFPLE9BQU8sQ0FBQyxDQUFDLFNBQVMsRUFBRSxDQUFDO1lBRXBFLGlCQUFpQixDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUVuQyxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDO1lBRXZCLE9BQU8sUUFBUSxDQUFDLElBQUksQ0FBQztRQUN2QixDQUFDO0tBQUE7SUFFSyxNQUFNLENBQ1YsT0FBOEI7O1lBRTlCLE1BQU0sUUFBUSxHQUFHLE1BQU0sSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUksT0FBTyxDQUFDLENBQUMsU0FBUyxFQUFFLENBQUM7WUFFbEUsaUJBQWlCLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1lBRW5DLElBQUksQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUM7WUFFdkIsT0FBTyxRQUFRLENBQUMsSUFBSSxDQUFDO1FBQ3ZCLENBQUM7S0FBQTs7OztZQWxDRixVQUFVLFNBQUM7Z0JBQ1YsVUFBVSxFQUFFLE1BQU07YUFDbkI7OztZQVJRLE1BQU07WUFFTixlQUFlIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBBcG9sbG8gfSBmcm9tICdhcG9sbG8tYW5ndWxhcic7XHJcbmltcG9ydCB7IFF1ZXJ5T3B0aW9ucywgTXV0YXRpb25PcHRpb25zIH0gZnJvbSAnQGFwb2xsby9jbGllbnQvY29yZSc7XHJcbmltcG9ydCB7IEtleUdyYXBoU2VydmljZSB9IGZyb20gJy4uL2NyeXB0b2dyYXBoeS9rZXktZ3JhcGguc2VydmljZSc7XHJcbmltcG9ydCB7IEhhc0tleUdyYXBoIH0gZnJvbSAnLi4vY3J5cHRvZ3JhcGh5L2NyeXB0b2dyYXBoeS50eXBlcyc7XHJcbmltcG9ydCB7IGhhbmRsZUFwb2xsb0Vycm9yIH0gZnJvbSAnLi4vX2NvbW1vbi9leGNlcHRpb25zJztcclxuXHJcbkBJbmplY3RhYmxlKHtcclxuICBwcm92aWRlZEluOiAncm9vdCcsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBMckFwb2xsb1NlcnZpY2Uge1xyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgYXBvbGxvOiBBcG9sbG8sIHByaXZhdGUga2V5R3JhcGg6IEtleUdyYXBoU2VydmljZSkge31cclxuXHJcbiAgcHJpdmF0ZSBhZGRLZXlzKHJlc3BvbnNlKSB7XHJcbiAgICBpZiAoKHJlc3BvbnNlLmRhdGEgYXMgSGFzS2V5R3JhcGgpLmtleUdyYXBoKSB7XHJcbiAgICAgIHRoaXMua2V5R3JhcGguYWRkS2V5cygocmVzcG9uc2UuZGF0YSBhcyBIYXNLZXlHcmFwaCkua2V5R3JhcGgpO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgYXN5bmMgcXVlcnk8VCwgViA9IHsgW2tleTogc3RyaW5nXTogYW55IH0+KFxyXG4gICAgb3B0aW9uczogUXVlcnlPcHRpb25zPFY+XHJcbiAgKTogUHJvbWlzZTxUPiB7XHJcbiAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IHRoaXMuYXBvbGxvLnF1ZXJ5PFQsIFY+KG9wdGlvbnMpLnRvUHJvbWlzZSgpO1xyXG5cclxuICAgIGhhbmRsZUFwb2xsb0Vycm9yKHJlc3BvbnNlLmVycm9ycyk7XHJcblxyXG4gICAgdGhpcy5hZGRLZXlzKHJlc3BvbnNlKTtcclxuXHJcbiAgICByZXR1cm4gcmVzcG9uc2UuZGF0YTtcclxuICB9XHJcblxyXG4gIGFzeW5jIG11dGF0ZTxUIGV4dGVuZHMgYW55LCBWID0geyBba2V5OiBzdHJpbmddOiBhbnkgfT4oXHJcbiAgICBvcHRpb25zOiBNdXRhdGlvbk9wdGlvbnM8VCwgVj5cclxuICApOiBQcm9taXNlPFQ+IHtcclxuICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgdGhpcy5hcG9sbG8ubXV0YXRlPFQ+KG9wdGlvbnMpLnRvUHJvbWlzZSgpO1xyXG5cclxuICAgIGhhbmRsZUFwb2xsb0Vycm9yKHJlc3BvbnNlLmVycm9ycyk7XHJcblxyXG4gICAgdGhpcy5hZGRLZXlzKHJlc3BvbnNlKTtcclxuXHJcbiAgICByZXR1cm4gcmVzcG9uc2UuZGF0YTtcclxuICB9XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export * from './lr-graphql.service';
|
|
2
|
+
export * from './lr-merged-mutation';
|
|
3
|
+
export * from './lr-mutation';
|
|
4
|
+
export * from './lr-mutation-base';
|
|
5
|
+
export * from './lr.service';
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiQzovUHJvamVjdHMvbmV3cmVwby9rYy1jbGllbnQvcHJvamVjdHMvY29yZS9zcmMvIiwic291cmNlcyI6WyJsaWIvYXBpL2xyLWdyYXBocWwvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsZUFBZSxDQUFDO0FBQzlCLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2xyLWdyYXBocWwuc2VydmljZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbHItbWVyZ2VkLW11dGF0aW9uJztcclxuZXhwb3J0ICogZnJvbSAnLi9sci1tdXRhdGlvbic7XHJcbmV4cG9ydCAqIGZyb20gJy4vbHItbXV0YXRpb24tYmFzZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbHIuc2VydmljZSc7XHJcbiJdfQ==
|
|
@@ -0,0 +1,155 @@
|
|
|
1
|
+
import { __awaiter, __decorate } from "tslib";
|
|
2
|
+
import * as lodash from 'lodash';
|
|
3
|
+
import { Injectable, NgZone } from '@angular/core';
|
|
4
|
+
import { Apollo } from 'apollo-angular';
|
|
5
|
+
import { KeyGraphService } from '../../cryptography/key-graph.service';
|
|
6
|
+
import { handleApolloError, LrBadStateException, LrUnsupportedException, } from '../../_common/exceptions';
|
|
7
|
+
import { FetchKeyGraphField, KeyGraphField } from '../../_common/queries.gql';
|
|
8
|
+
import { getQuery, getMutation } from '../../_common/ast';
|
|
9
|
+
import gql from 'graphql-tag';
|
|
10
|
+
import { QueryProcessorService } from '../query-processor';
|
|
11
|
+
import { RunOutsideAngular } from '../../_common/run-outside-angular';
|
|
12
|
+
import * as gqlPrinter from 'graphql/language/printer';
|
|
13
|
+
import { LrMergedMutation } from './lr-merged-mutation';
|
|
14
|
+
import * as i0 from "@angular/core";
|
|
15
|
+
import * as i1 from "apollo-angular";
|
|
16
|
+
import * as i2 from "../../cryptography/key-graph.service";
|
|
17
|
+
import * as i3 from "../query-processor/query-processor.service";
|
|
18
|
+
// Data structures
|
|
19
|
+
// --------------------------------------------------------------------------
|
|
20
|
+
const keyGraphFieldAstSelection = getQuery(gql `
|
|
21
|
+
query {
|
|
22
|
+
${KeyGraphField}
|
|
23
|
+
}
|
|
24
|
+
`).selectionSet.selections[0];
|
|
25
|
+
const fetchKeyGraphFieldAstSelection = getQuery(gql `
|
|
26
|
+
query {
|
|
27
|
+
${FetchKeyGraphField}
|
|
28
|
+
}
|
|
29
|
+
`).selectionSet.selections[0];
|
|
30
|
+
let LrGraphQLService = class LrGraphQLService {
|
|
31
|
+
constructor(ngZone, apollo, keyGraph, queryProcessor) {
|
|
32
|
+
this.ngZone = ngZone;
|
|
33
|
+
this.apollo = apollo;
|
|
34
|
+
this.keyGraph = keyGraph;
|
|
35
|
+
this.queryProcessor = queryProcessor;
|
|
36
|
+
this.stats = {
|
|
37
|
+
queryCount: 0,
|
|
38
|
+
mutationCount: 0,
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
query(options) {
|
|
42
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
43
|
+
// Make copies to avoid side effect.
|
|
44
|
+
options = lodash.cloneDeep(options);
|
|
45
|
+
// Append the key graph query
|
|
46
|
+
const includeKeyGraph = this.isIncludeKeyGraph(options.includeKeyGraph);
|
|
47
|
+
if (includeKeyGraph) {
|
|
48
|
+
const operation = getQuery(options.query);
|
|
49
|
+
operation.selectionSet.selections = [
|
|
50
|
+
...operation.selectionSet.selections,
|
|
51
|
+
keyGraphFieldAstSelection,
|
|
52
|
+
];
|
|
53
|
+
}
|
|
54
|
+
const response = yield this.apollo.query(options).toPromise();
|
|
55
|
+
this.stats.queryCount++;
|
|
56
|
+
handleApolloError(response.errors);
|
|
57
|
+
this.addKeys(response);
|
|
58
|
+
const data = yield this.queryProcessor.processQuery(response.data, options.processorOptions);
|
|
59
|
+
return data;
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
lrMutateImpl(lrMutation, options) {
|
|
63
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
64
|
+
if (options === null || options === void 0 ? void 0 : options.variables) {
|
|
65
|
+
throw new LrUnsupportedException('Unsupported field: "options.variables"');
|
|
66
|
+
}
|
|
67
|
+
if (lrMutation.executed) {
|
|
68
|
+
throw new LrBadStateException('LrMutation has already executed. LrMutation can only be used once in a lrMutate() call. Create new instances of LrMutation.');
|
|
69
|
+
}
|
|
70
|
+
lrMutation.setExecuted();
|
|
71
|
+
return this.apolloMutate(Object.assign(Object.assign({}, options), lrMutation.lrMutationData))
|
|
72
|
+
.then((res) => {
|
|
73
|
+
// Resolve promises set on the lrMutation rather than the lrMutate() call.
|
|
74
|
+
lrMutation.resolve(res);
|
|
75
|
+
// Still need to return value to the promise waiting for the results of lrMutate().
|
|
76
|
+
return res;
|
|
77
|
+
})
|
|
78
|
+
.catch((error) => {
|
|
79
|
+
lrMutation.reject(error);
|
|
80
|
+
throw error;
|
|
81
|
+
});
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
apolloMutate(options) {
|
|
85
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
86
|
+
// Make copies to avoid side effect.
|
|
87
|
+
options = Object.assign(Object.assign({}, options), { mutation: lodash.cloneDeep(options.mutation) });
|
|
88
|
+
// Append the key graph query
|
|
89
|
+
const includeKeyGraph = this.isIncludeKeyGraph(options.includeKeyGraph);
|
|
90
|
+
if (includeKeyGraph) {
|
|
91
|
+
const operation = getMutation(options.mutation);
|
|
92
|
+
operation.selectionSet.selections = [
|
|
93
|
+
...operation.selectionSet.selections,
|
|
94
|
+
fetchKeyGraphFieldAstSelection,
|
|
95
|
+
];
|
|
96
|
+
}
|
|
97
|
+
// Format to string and parse again. This allows the "loc": { "start": ... }
|
|
98
|
+
// part of the DocumentNode to be correctly setup. It's extra processing
|
|
99
|
+
// in serialising and parsing, but probably minimal overhead.
|
|
100
|
+
options.mutation = gql(gqlPrinter.print(options.mutation));
|
|
101
|
+
const response = yield this.apollo.mutate(options).toPromise();
|
|
102
|
+
this.stats.mutationCount++;
|
|
103
|
+
handleApolloError(response.errors);
|
|
104
|
+
this.addKeys(response);
|
|
105
|
+
const data = yield this.queryProcessor.processQuery(response.data, options.processorOptions);
|
|
106
|
+
return data;
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
statsSnapshot() {
|
|
110
|
+
return lodash.cloneDeep(this.stats);
|
|
111
|
+
}
|
|
112
|
+
addKeys(response) {
|
|
113
|
+
if (response.data.keyGraph) {
|
|
114
|
+
this.keyGraph.addKeys(response.data.keyGraph);
|
|
115
|
+
delete response.data.keyGraph;
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
isIncludeKeyGraph(includeKeyGraph) {
|
|
119
|
+
// Default to true when null or undefined.
|
|
120
|
+
return includeKeyGraph == null ? true : false;
|
|
121
|
+
}
|
|
122
|
+
lrMutate(lrMutations, options) {
|
|
123
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
124
|
+
if (lrMutations instanceof Array) {
|
|
125
|
+
const merged = LrMergedMutation.create(yield Promise.all(lrMutations));
|
|
126
|
+
yield this.lrMutateImpl(merged, options);
|
|
127
|
+
return merged.promise;
|
|
128
|
+
}
|
|
129
|
+
else {
|
|
130
|
+
const resolved = yield lrMutations;
|
|
131
|
+
yield this.lrMutateImpl(resolved, options);
|
|
132
|
+
return resolved.promise;
|
|
133
|
+
}
|
|
134
|
+
});
|
|
135
|
+
}
|
|
136
|
+
};
|
|
137
|
+
LrGraphQLService.ɵprov = i0.ɵɵdefineInjectable({ factory: function LrGraphQLService_Factory() { return new LrGraphQLService(i0.ɵɵinject(i0.NgZone), i0.ɵɵinject(i1.Apollo), i0.ɵɵinject(i2.KeyGraphService), i0.ɵɵinject(i3.QueryProcessorService)); }, token: LrGraphQLService, providedIn: "root" });
|
|
138
|
+
LrGraphQLService.decorators = [
|
|
139
|
+
{ type: Injectable, args: [{
|
|
140
|
+
providedIn: 'root',
|
|
141
|
+
},] }
|
|
142
|
+
];
|
|
143
|
+
LrGraphQLService.ctorParameters = () => [
|
|
144
|
+
{ type: NgZone },
|
|
145
|
+
{ type: Apollo },
|
|
146
|
+
{ type: KeyGraphService },
|
|
147
|
+
{ type: QueryProcessorService }
|
|
148
|
+
];
|
|
149
|
+
LrGraphQLService = __decorate([
|
|
150
|
+
RunOutsideAngular({
|
|
151
|
+
ngZoneName: 'ngZone',
|
|
152
|
+
})
|
|
153
|
+
], LrGraphQLService);
|
|
154
|
+
export { LrGraphQLService };
|
|
155
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lr-graphql.service.js","sourceRoot":"C:/Projects/newrepo/kc-client/projects/core/src/","sources":["lib/api/lr-graphql/lr-graphql.service.ts"],"names":[],"mappings":"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","sourcesContent":["import * as lodash from 'lodash';\r\nimport { Injectable, NgZone } from '@angular/core';\r\nimport { Apollo } from 'apollo-angular';\r\nimport {\r\n  QueryOptions,\r\n  MutationOptions,\r\n  OperationVariables,\r\n  FetchPolicy,\r\n} from '@apollo/client/core';\r\nimport { MutationBaseOptions } from '@apollo/client/core/watchQueryOptions';\r\nimport { KeyGraphService } from '../../cryptography/key-graph.service';\r\nimport { HasKeyGraph } from '../../cryptography/cryptography.types';\r\nimport {\r\n  handleApolloError,\r\n  LrBadStateException,\r\n  LrUnsupportedException,\r\n} from '../../_common/exceptions';\r\nimport { FetchKeyGraphField, KeyGraphField } from '../../_common/queries.gql';\r\nimport { TypedDocumentNode, getQuery, getMutation } from '../../_common/ast';\r\nimport gql from 'graphql-tag';\r\nimport { ProcessorOptions, QueryProcessorService } from '../query-processor';\r\nimport { RunOutsideAngular } from '../../_common/run-outside-angular';\r\nimport { FieldNode } from 'graphql';\r\nimport { LrMutationBase } from './lr-mutation-base';\r\nimport * as gqlPrinter from 'graphql/language/printer';\r\nimport { LrMergedMutation } from './lr-merged-mutation';\r\n\r\n// Data structures\r\n// --------------------------------------------------------------------------\r\nconst keyGraphFieldAstSelection = getQuery(gql`\r\nquery {\r\n  ${KeyGraphField}\r\n}\r\n`).selectionSet.selections[0] as FieldNode;\r\n\r\nconst fetchKeyGraphFieldAstSelection = getQuery(gql`\r\nquery {\r\n  ${FetchKeyGraphField}\r\n}\r\n`).selectionSet.selections[0] as FieldNode;\r\n\r\n// const keyGraphFieldAstSelection = () =>\r\n//   lodash.deepClone(_keyGraphFieldAstSelection) as FieldNode;\r\n// const fetchKeyGraphFieldAstSelection = () =>\r\n//   lodash.deepClone(_fetchKeyGraphFieldAstSelection) as FieldNode;\r\n\r\nexport interface LrQueryOptions<T, TVariables>\r\n  extends QueryOptions<TVariables> {\r\n  query: TypedDocumentNode<T>;\r\n  includeKeyGraph?: boolean;\r\n  processorOptions?: ProcessorOptions;\r\n}\r\n\r\n// Copied from MutationOptions\r\n// Removed required field \"mutation\". The \"variables\" field is still there\r\n// but it's dynamically checked.\r\nexport interface LrMutationOptions<\r\n  T = {\r\n    [key: string]: any;\r\n  },\r\n  TVariables = OperationVariables\r\n> extends MutationBaseOptions<T, TVariables> {\r\n  context?: any;\r\n  fetchPolicy?: FetchPolicy;\r\n  includeKeyGraph?: boolean;\r\n}\r\n\r\n// The \"mutation\" and \"variable\" fields are inherited but dynamically prohibited because\r\n// they are provided by LrMutation. It's a bit unclean but avoids a lot of typing work.\r\nexport interface LrApolloMutationOptions<T, TVariables = OperationVariables>\r\n  extends MutationOptions<T, TVariables> {\r\n  mutation: TypedDocumentNode<T>;\r\n  includeKeyGraph?: boolean;\r\n  processorOptions?: ProcessorOptions;\r\n}\r\n\r\ninterface LrGraphQLServiceStats {\r\n  queryCount: number;\r\n  mutationCount: number;\r\n}\r\n\r\n@RunOutsideAngular({\r\n  ngZoneName: 'ngZone',\r\n})\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class LrGraphQLService {\r\n  private stats: LrGraphQLServiceStats = {\r\n    queryCount: 0,\r\n    mutationCount: 0,\r\n  };\r\n\r\n  constructor(\r\n    private ngZone: NgZone,\r\n    private apollo: Apollo,\r\n    private keyGraph: KeyGraphService,\r\n    private queryProcessor: QueryProcessorService\r\n  ) {}\r\n\r\n  async query<T, V = { [key: string]: any }>(\r\n    options: LrQueryOptions<T, V>\r\n  ): Promise<T> {\r\n    // Make copies to avoid side effect.\r\n    options = lodash.cloneDeep(options);\r\n\r\n    // Append the key graph query\r\n    const includeKeyGraph = this.isIncludeKeyGraph(options.includeKeyGraph);\r\n    if (includeKeyGraph) {\r\n      const operation = getQuery(options.query);\r\n      operation.selectionSet.selections = [\r\n        ...operation.selectionSet.selections,\r\n        keyGraphFieldAstSelection,\r\n      ];\r\n    }\r\n\r\n    const response = await this.apollo.query<T, V>(options).toPromise();\r\n\r\n    this.stats.queryCount++;\r\n\r\n    handleApolloError(response.errors);\r\n\r\n    this.addKeys(response);\r\n\r\n    const data = await this.queryProcessor.processQuery(\r\n      response.data,\r\n      options.processorOptions\r\n    );\r\n\r\n    return data;\r\n  }\r\n\r\n  private async lrMutateImpl(lrMutation, options?) {\r\n    if (options?.variables) {\r\n      throw new LrUnsupportedException(\r\n        'Unsupported field: \"options.variables\"'\r\n      );\r\n    }\r\n\r\n    if (lrMutation.executed) {\r\n      throw new LrBadStateException(\r\n        'LrMutation has already executed. LrMutation can only be used once in a lrMutate() call. Create new instances of LrMutation.'\r\n      );\r\n    }\r\n\r\n    lrMutation.setExecuted();\r\n\r\n    return this.apolloMutate({\r\n      ...options,\r\n      ...lrMutation.lrMutationData,\r\n    })\r\n      .then((res) => {\r\n        // Resolve promises set on the lrMutation rather than the lrMutate() call.\r\n        lrMutation.resolve(res);\r\n        // Still need to return value to the promise waiting for the results of lrMutate().\r\n        return res;\r\n      })\r\n      .catch((error) => {\r\n        lrMutation.reject(error);\r\n        throw error;\r\n      });\r\n  }\r\n\r\n  async apolloMutate<T extends any, TVariables = { [key: string]: any }>(\r\n    options: LrApolloMutationOptions<T, TVariables>\r\n  ): Promise<T> {\r\n    // Make copies to avoid side effect.\r\n    options = {\r\n      ...options,\r\n      mutation: lodash.cloneDeep(options.mutation),\r\n    };\r\n\r\n    // Append the key graph query\r\n    const includeKeyGraph = this.isIncludeKeyGraph(options.includeKeyGraph);\r\n\r\n    if (includeKeyGraph) {\r\n      const operation = getMutation(options.mutation);\r\n      operation.selectionSet.selections = [\r\n        ...operation.selectionSet.selections,\r\n        fetchKeyGraphFieldAstSelection,\r\n      ];\r\n    }\r\n\r\n    // Format to string and parse again. This allows the \"loc\": { \"start\": ... }\r\n    // part of the DocumentNode to be correctly setup. It's extra processing\r\n    // in serialising and parsing, but probably minimal overhead.\r\n    options.mutation = gql(gqlPrinter.print(options.mutation));\r\n\r\n    const response = await this.apollo.mutate<T>(options).toPromise();\r\n\r\n    this.stats.mutationCount++;\r\n\r\n    handleApolloError(response.errors);\r\n\r\n    this.addKeys(response);\r\n\r\n    const data = await this.queryProcessor.processQuery(\r\n      response.data,\r\n      options.processorOptions\r\n    );\r\n\r\n    return data;\r\n  }\r\n\r\n  statsSnapshot(): LrGraphQLServiceStats {\r\n    return lodash.cloneDeep(this.stats);\r\n  }\r\n\r\n  private addKeys(response) {\r\n    if ((response.data as HasKeyGraph).keyGraph) {\r\n      this.keyGraph.addKeys((response.data as HasKeyGraph).keyGraph);\r\n      delete response.data.keyGraph;\r\n    }\r\n  }\r\n\r\n  private isIncludeKeyGraph(includeKeyGraph) {\r\n    // Default to true when null or undefined.\r\n    return includeKeyGraph == null ? true : false;\r\n  }\r\n\r\n  async lrMutate<T1, TVariables1, T2, TVariables2>(\r\n    lrMutations: [\r\n      LrMutationMayAsync<T1, TVariables1>,\r\n      LrMutationMayAsync<T2, TVariables2>\r\n    ],\r\n    options?: LrMutationOptions\r\n  ): Promise<[T1, T2]>;\r\n\r\n  async lrMutate<T1, TVariables1, T2, TVariables2, T3, TVariables3>(\r\n    lrMutations: [\r\n      LrMutationMayAsync<T1, TVariables1>,\r\n      LrMutationMayAsync<T2, TVariables2>,\r\n      LrMutationMayAsync<T3, TVariables3>\r\n    ],\r\n    options?: LrMutationOptions\r\n  ): Promise<[T1, T2, T3]>;\r\n\r\n  async lrMutate<\r\n    T1,\r\n    TVariables1,\r\n    T2,\r\n    TVariables2,\r\n    T3,\r\n    TVariables3,\r\n    T4,\r\n    TVariables4\r\n  >(\r\n    lrMutations: [\r\n      LrMutationMayAsync<T1, TVariables1>,\r\n      LrMutationMayAsync<T2, TVariables2>,\r\n      LrMutationMayAsync<T3, TVariables3>,\r\n      LrMutationMayAsync<T4, TVariables4>\r\n    ],\r\n    options?: LrMutationOptions\r\n  ): Promise<[T1, T2, T3, T4]>;\r\n\r\n  async lrMutate<\r\n    T1,\r\n    TVariables1,\r\n    T2,\r\n    TVariables2,\r\n    T3,\r\n    TVariables3,\r\n    T4,\r\n    TVariables4,\r\n    T5,\r\n    TVariables5\r\n  >(\r\n    lrMutations: [\r\n      LrMutationMayAsync<T1, TVariables1>,\r\n      LrMutationMayAsync<T2, TVariables2>,\r\n      LrMutationMayAsync<T3, TVariables3>,\r\n      LrMutationMayAsync<T4, TVariables4>,\r\n      LrMutationMayAsync<T5, TVariables5>\r\n    ],\r\n    options?: LrMutationOptions\r\n  ): Promise<[T1, T2, T3, T4, T5]>;\r\n\r\n  async lrMutate<T, TVariables = { [key: string]: any }>(\r\n    lrMutation: LrMutationMayAsync<T, TVariables>,\r\n    options?: LrMutationOptions<T, TVariables>\r\n  ): Promise<T>;\r\n\r\n  async lrMutate<T, TVariables = { [key: string]: any }>(\r\n    lrMutations:\r\n      | LrMutationMayAsync<T, TVariables>[]\r\n      | LrMutationMayAsync<T, TVariables>,\r\n    options?: LrMutationOptions\r\n  );\r\n\r\n  async lrMutate<T, TVariables = { [key: string]: any }>(\r\n    lrMutations:\r\n      | LrMutationMayAsync<T, TVariables>[]\r\n      | LrMutationMayAsync<T, TVariables>,\r\n    options?: LrMutationOptions\r\n  ) {\r\n    if (lrMutations instanceof Array) {\r\n      const merged = LrMergedMutation.create(await Promise.all(lrMutations));\r\n      await this.lrMutateImpl(merged, options);\r\n      return merged.promise;\r\n    } else {\r\n      const resolved = await lrMutations;\r\n      await this.lrMutateImpl(resolved, options);\r\n      return resolved.promise;\r\n    }\r\n  }\r\n}\r\n\r\ntype LrMutationMayAsync<T, TVariables> =\r\n  | LrMutationBase<T, TVariables>\r\n  | Promise<LrMutationBase<T, TVariables>>\r\n  | LrMergedMutation<T>\r\n  | Promise<LrMergedMutation<T>>;\r\n"]}
|
|
@@ -0,0 +1,213 @@
|
|
|
1
|
+
import { LrBadLogicException, LrUnsupportedException, } from '../../_common/exceptions';
|
|
2
|
+
import { LrMutation } from './lr-mutation';
|
|
3
|
+
import { LrMutationBase } from './lr-mutation-base';
|
|
4
|
+
import { getAliasOrName, getFragments, getMutation } from '../../_common/ast';
|
|
5
|
+
import * as ast from '../../_common/ast';
|
|
6
|
+
import * as lodash from 'lodash';
|
|
7
|
+
const lrMergedMutationDoc = {
|
|
8
|
+
kind: 'Document',
|
|
9
|
+
definitions: [
|
|
10
|
+
{
|
|
11
|
+
kind: 'OperationDefinition',
|
|
12
|
+
operation: 'mutation',
|
|
13
|
+
name: {
|
|
14
|
+
kind: 'Name',
|
|
15
|
+
value: 'lrMergedMutation',
|
|
16
|
+
},
|
|
17
|
+
variableDefinitions: [],
|
|
18
|
+
directives: [],
|
|
19
|
+
selectionSet: {
|
|
20
|
+
kind: 'SelectionSet',
|
|
21
|
+
selections: [],
|
|
22
|
+
},
|
|
23
|
+
},
|
|
24
|
+
],
|
|
25
|
+
};
|
|
26
|
+
export class LrMergedMutation extends LrMutationBase {
|
|
27
|
+
constructor(lrMutations) {
|
|
28
|
+
super();
|
|
29
|
+
this.lrMutations = lrMutations;
|
|
30
|
+
const { mutation, variables, prefixes } = this.merge();
|
|
31
|
+
this.mutation = mutation;
|
|
32
|
+
this.variables = variables;
|
|
33
|
+
this.prefixes = prefixes;
|
|
34
|
+
this.descendants = this.getDescendants();
|
|
35
|
+
}
|
|
36
|
+
static create(lrMutations) {
|
|
37
|
+
return new LrMergedMutation(lrMutations);
|
|
38
|
+
}
|
|
39
|
+
getDescendants() {
|
|
40
|
+
const ret = new Set();
|
|
41
|
+
const addOrThrow = (item) => {
|
|
42
|
+
if (ret.has(item)) {
|
|
43
|
+
throw new LrBadLogicException('Classes that are derived from LrMutationBase can not be used more than once in a merged mutation.');
|
|
44
|
+
}
|
|
45
|
+
ret.add(item);
|
|
46
|
+
};
|
|
47
|
+
this.lrMutations.forEach((lrMutation) => {
|
|
48
|
+
if (lrMutation instanceof LrMutation) {
|
|
49
|
+
addOrThrow(lrMutation);
|
|
50
|
+
}
|
|
51
|
+
else if (lrMutation instanceof LrMergedMutation) {
|
|
52
|
+
lrMutation.descendants.forEach((t) => addOrThrow(t));
|
|
53
|
+
}
|
|
54
|
+
else {
|
|
55
|
+
throw new LrUnsupportedException(`LrMergeMutation can not handle class: ${lrMutation.constructor.name}`);
|
|
56
|
+
}
|
|
57
|
+
});
|
|
58
|
+
return ret;
|
|
59
|
+
}
|
|
60
|
+
resolve(value) {
|
|
61
|
+
// Resolves any promises waiting for the child mutations
|
|
62
|
+
for (let i = 0; i < this.lrMutations.length; ++i) {
|
|
63
|
+
const prefix = this.prefixes[i];
|
|
64
|
+
// Remove the prefix and resolve child mutation.
|
|
65
|
+
const res = {};
|
|
66
|
+
for (const key2 in value) {
|
|
67
|
+
if (key2.startsWith(prefix)) {
|
|
68
|
+
const originalKey = key2.slice(prefix.length);
|
|
69
|
+
res[originalKey] = value[key2];
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
this.lrMutations[i].resolve(res);
|
|
73
|
+
}
|
|
74
|
+
// Resolves to the result of children
|
|
75
|
+
Promise.all(this.lrMutations.map((m) => m.promise)).then((childValues) => {
|
|
76
|
+
// Resolves any promises waiting for the current merged mutation
|
|
77
|
+
super.resolve(childValues);
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
reject(reason) {
|
|
81
|
+
super.reject(reason);
|
|
82
|
+
this.lrMutations.forEach((lrMutation) => lrMutation.reject(reason));
|
|
83
|
+
}
|
|
84
|
+
setExecuted() {
|
|
85
|
+
super.setExecuted();
|
|
86
|
+
this.lrMutations.forEach((lrMutation) => lrMutation.setExecuted());
|
|
87
|
+
}
|
|
88
|
+
renameVariableDefinition(varDef, prefix) {
|
|
89
|
+
return Object.assign(Object.assign({}, varDef), { variable: Object.assign(Object.assign({}, varDef.variable), { name: ast.name(prefix + varDef.variable.name.value) }) });
|
|
90
|
+
}
|
|
91
|
+
renameVariableDefinitions(varDefs, prefix) {
|
|
92
|
+
return varDefs.map((varDef) => this.renameVariableDefinition(varDef, prefix));
|
|
93
|
+
}
|
|
94
|
+
renameArgument(arg, prefix) {
|
|
95
|
+
if (arg.value.kind !== 'Variable') {
|
|
96
|
+
return arg;
|
|
97
|
+
}
|
|
98
|
+
return Object.assign(Object.assign({}, arg), { value: Object.assign(Object.assign({}, arg.value), { name: ast.name(prefix + arg.value.name.value) }) });
|
|
99
|
+
}
|
|
100
|
+
renameField(selection, prefix) {
|
|
101
|
+
// Only handling type Field
|
|
102
|
+
if (selection.kind !== 'Field') {
|
|
103
|
+
return selection;
|
|
104
|
+
}
|
|
105
|
+
const alias = prefix + getAliasOrName(selection);
|
|
106
|
+
const args = selection.arguments.map((arg) => this.renameArgument(arg, prefix));
|
|
107
|
+
return Object.assign(Object.assign({}, selection), { alias: {
|
|
108
|
+
kind: 'Name',
|
|
109
|
+
value: alias,
|
|
110
|
+
}, arguments: args });
|
|
111
|
+
}
|
|
112
|
+
renameFragmentSpread(selection, prefix) {
|
|
113
|
+
return Object.assign(Object.assign({}, selection), { name: ast.name(prefix + selection.name.value) });
|
|
114
|
+
}
|
|
115
|
+
processSelection(selection, prefix) {
|
|
116
|
+
switch (selection.kind) {
|
|
117
|
+
case 'FragmentSpread':
|
|
118
|
+
return this.renameFragmentSpread(selection, prefix);
|
|
119
|
+
case 'Field':
|
|
120
|
+
// Continue to process children for nested selections.
|
|
121
|
+
if (selection.selectionSet) {
|
|
122
|
+
return Object.assign(Object.assign({}, selection), { selectionSet: this.processSelectionSet(selection.selectionSet, prefix) });
|
|
123
|
+
}
|
|
124
|
+
else {
|
|
125
|
+
return selection;
|
|
126
|
+
}
|
|
127
|
+
default:
|
|
128
|
+
return selection;
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
processSelectionSet(selectionSet, prefix) {
|
|
132
|
+
return Object.assign(Object.assign({}, selectionSet), { selections: selectionSet.selections.map((selection) => this.processSelection(selection, prefix)) });
|
|
133
|
+
}
|
|
134
|
+
renameSelections(selections, prefix) {
|
|
135
|
+
return selections.map((selection) => {
|
|
136
|
+
switch (selection.kind) {
|
|
137
|
+
case 'Field':
|
|
138
|
+
const field = this.renameField(selection, prefix);
|
|
139
|
+
return this.processSelection(field, prefix);
|
|
140
|
+
default:
|
|
141
|
+
return selection;
|
|
142
|
+
}
|
|
143
|
+
});
|
|
144
|
+
}
|
|
145
|
+
renameFragmentDefinition(fragment, prefix) {
|
|
146
|
+
const ret = Object.assign(Object.assign({}, fragment), { name: ast.name(prefix + fragment.name.value) });
|
|
147
|
+
if (fragment.selectionSet) {
|
|
148
|
+
ret.selectionSet = this.processSelectionSet(fragment.selectionSet, prefix);
|
|
149
|
+
}
|
|
150
|
+
return ret;
|
|
151
|
+
}
|
|
152
|
+
renameFragmentDefinitions(fragments, prefix) {
|
|
153
|
+
return fragments.map((fragment) => this.renameFragmentDefinition(fragment, prefix));
|
|
154
|
+
}
|
|
155
|
+
merge() {
|
|
156
|
+
let variableDefinitions = [];
|
|
157
|
+
let selections = [];
|
|
158
|
+
const mergedVariables = {};
|
|
159
|
+
let mergedFragments = [];
|
|
160
|
+
const prefixes = [];
|
|
161
|
+
// Just wait for everything to resolve because we have to
|
|
162
|
+
// merge the doc synchronously.
|
|
163
|
+
this.lrMutations.forEach((lrMutation, idx) => {
|
|
164
|
+
const { mutation, variables } = lrMutation.lrMutationData;
|
|
165
|
+
const childMutationNode = getMutation(mutation);
|
|
166
|
+
// Prefixing all mutation fields so they don't conflict.
|
|
167
|
+
let prefix = `item${idx}_`;
|
|
168
|
+
if (childMutationNode.name) {
|
|
169
|
+
prefix += childMutationNode.name.value + '_';
|
|
170
|
+
}
|
|
171
|
+
prefixes.push(prefix);
|
|
172
|
+
// Rename and merge variables
|
|
173
|
+
variableDefinitions = [
|
|
174
|
+
...variableDefinitions,
|
|
175
|
+
...this.renameVariableDefinitions(childMutationNode.variableDefinitions, prefix),
|
|
176
|
+
];
|
|
177
|
+
// Rename and merge selections
|
|
178
|
+
selections = [
|
|
179
|
+
...selections,
|
|
180
|
+
...this.renameSelections(childMutationNode.selectionSet.selections, prefix),
|
|
181
|
+
];
|
|
182
|
+
// TODO Rename and merge fragments
|
|
183
|
+
// Rename and merge variables
|
|
184
|
+
for (const key2 of Object.keys(variables)) {
|
|
185
|
+
mergedVariables[prefix + key2] = variables[key2];
|
|
186
|
+
}
|
|
187
|
+
// Rename and merge fragments
|
|
188
|
+
const fragments = getFragments(mutation);
|
|
189
|
+
mergedFragments = [
|
|
190
|
+
...mergedFragments,
|
|
191
|
+
...this.renameFragmentDefinitions(fragments, prefix),
|
|
192
|
+
];
|
|
193
|
+
});
|
|
194
|
+
const mergedMutation = lodash.cloneDeep(lrMergedMutationDoc);
|
|
195
|
+
const mutationNode = getMutation(mergedMutation);
|
|
196
|
+
// Add in the mutation selections
|
|
197
|
+
mutationNode.selectionSet.selections = selections;
|
|
198
|
+
// Add in the variables
|
|
199
|
+
// variableDefinitions is readonly property.
|
|
200
|
+
mutationNode.variableDefinitions = variableDefinitions;
|
|
201
|
+
// Add in the fragments
|
|
202
|
+
mergedMutation.definitions = [
|
|
203
|
+
...mergedMutation.definitions,
|
|
204
|
+
...mergedFragments,
|
|
205
|
+
];
|
|
206
|
+
return {
|
|
207
|
+
mutation: mergedMutation,
|
|
208
|
+
variables: mergedVariables,
|
|
209
|
+
prefixes,
|
|
210
|
+
};
|
|
211
|
+
}
|
|
212
|
+
}
|
|
213
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lr-merged-mutation.js","sourceRoot":"C:/Projects/newrepo/kc-client/projects/core/src/","sources":["lib/api/lr-graphql/lr-merged-mutation.ts"],"names":[],"mappings":"AAUA,OAAO,EAEL,mBAAmB,EACnB,sBAAsB,GACvB,MAAM,0BAA0B,CAAC;AAClC,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACpD,OAAO,EAAE,cAAc,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAC9E,OAAO,KAAK,GAAG,MAAM,mBAAmB,CAAC;AACzC,OAAO,KAAK,MAAM,MAAM,QAAQ,CAAC;AAEjC,MAAM,mBAAmB,GAAiB;IACxC,IAAI,EAAE,UAAU;IAChB,WAAW,EAAE;QACX;YACE,IAAI,EAAE,qBAAqB;YAC3B,SAAS,EAAE,UAAU;YACrB,IAAI,EAAE;gBACJ,IAAI,EAAE,MAAM;gBACZ,KAAK,EAAE,kBAAkB;aAC1B;YACD,mBAAmB,EAAE,EAAE;YACvB,UAAU,EAAE,EAAE;YACd,YAAY,EAAE;gBACZ,IAAI,EAAE,cAAc;gBACpB,UAAU,EAAE,EAAE;aACf;SACF;KACF;CAMF,CAAC;AAEF,MAAM,OAAO,gBAAoB,SAAQ,cAAiB;IAIxD,YAA4B,WAAkC;QAC5D,KAAK,EAAE,CAAC;QADkB,gBAAW,GAAX,WAAW,CAAuB;QAG5D,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC;QACvD,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;IAC3C,CAAC;IAsCD,MAAM,CAAC,MAAM,CAAC,WAAkC;QAC9C,OAAO,IAAI,gBAAgB,CAAC,WAAW,CAAC,CAAC;IAC3C,CAAC;IAEO,cAAc;QACpB,MAAM,GAAG,GAAG,IAAI,GAAG,EAAuB,CAAC;QAE3C,MAAM,UAAU,GAAG,CAAC,IAAI,EAAE,EAAE;YAC1B,IAAI,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;gBACjB,MAAM,IAAI,mBAAmB,CAC3B,mGAAmG,CACpG,CAAC;aACH;YAED,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAChB,CAAC,CAAC;QAEF,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,UAAU,EAAE,EAAE;YACtC,IAAI,UAAU,YAAY,UAAU,EAAE;gBACpC,UAAU,CAAC,UAAU,CAAC,CAAC;aACxB;iBAAM,IAAI,UAAU,YAAY,gBAAgB,EAAE;gBACjD,UAAU,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;aACtD;iBAAM;gBACL,MAAM,IAAI,sBAAsB,CAC9B,yCAAyC,UAAU,CAAC,WAAW,CAAC,IAAI,EAAE,CACvE,CAAC;aACH;QACH,CAAC,CAAC,CAAC;QAEH,OAAO,GAAG,CAAC;IACb,CAAC;IAED,OAAO,CAAC,KAAU;QAChB,wDAAwD;QACxD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,EAAE,CAAC,EAAE;YAChD,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;YAEhC,gDAAgD;YAChD,MAAM,GAAG,GAAQ,EAAE,CAAC;YACpB,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE;gBACxB,IAAI,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE;oBAC3B,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;oBAC9C,GAAG,CAAC,WAAW,CAAC,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC;iBAChC;aACF;YACD,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;SAClC;QAED,qCAAqC;QACrC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CACtD,CAAC,WAAgB,EAAE,EAAE;YACnB,gEAAgE;YAChE,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QAC7B,CAAC,CACF,CAAC;IACJ,CAAC;IAED,MAAM,CAAC,MAAY;QACjB,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QACrB,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC;IACtE,CAAC;IAED,WAAW;QACT,KAAK,CAAC,WAAW,EAAE,CAAC;QACpB,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC,CAAC;IACrE,CAAC;IAEO,wBAAwB,CAAC,MAA8B,EAAE,MAAM;QACrE,uCACK,MAAM,KACT,QAAQ,kCACH,MAAM,CAAC,QAAQ,KAClB,IAAI,EAAE,GAAG,CAAC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,OAErD;IACJ,CAAC;IAEO,yBAAyB,CAC/B,OAA8C,EAC9C,MAAM;QAEN,OAAO,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAC5B,IAAI,CAAC,wBAAwB,CAAC,MAAM,EAAE,MAAM,CAAC,CAC9C,CAAC;IACJ,CAAC;IAEO,cAAc,CAAC,GAAiB,EAAE,MAAM;QAC9C,IAAI,GAAG,CAAC,KAAK,CAAC,IAAI,KAAK,UAAU,EAAE;YACjC,OAAO,GAAG,CAAC;SACZ;QAED,uCACK,GAAG,KACN,KAAK,kCACA,GAAG,CAAC,KAAK,KACZ,IAAI,EAAE,GAAG,CAAC,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,OAE/C;IACJ,CAAC;IAEO,WAAW,CAAC,SAAoB,EAAE,MAAM;QAC9C,2BAA2B;QAC3B,IAAI,SAAS,CAAC,IAAI,KAAK,OAAO,EAAE;YAC9B,OAAO,SAAS,CAAC;SAClB;QAED,MAAM,KAAK,GAAG,MAAM,GAAG,cAAc,CAAC,SAAS,CAAC,CAAC;QACjD,MAAM,IAAI,GAAG,SAAS,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAC3C,IAAI,CAAC,cAAc,CAAC,GAAG,EAAE,MAAM,CAAC,CACjC,CAAC;QAEF,uCACK,SAAS,KACZ,KAAK,EAAE;gBACL,IAAI,EAAE,MAAM;gBACZ,KAAK,EAAE,KAAK;aACb,EACD,SAAS,EAAE,IAAI,IACf;IACJ,CAAC;IAEO,oBAAoB,CAC1B,SAA6B,EAC7B,MAAM;QAEN,uCACK,SAAS,KACZ,IAAI,EAAE,GAAG,CAAC,IAAI,CAAC,MAAM,GAAG,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,IAC7C;IACJ,CAAC;IAEO,gBAAgB,CAAC,SAAwB,EAAE,MAAM;QACvD,QAAQ,SAAS,CAAC,IAAI,EAAE;YACtB,KAAK,gBAAgB;gBACnB,OAAO,IAAI,CAAC,oBAAoB,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;YACtD,KAAK,OAAO;gBACV,sDAAsD;gBACtD,IAAI,SAAS,CAAC,YAAY,EAAE;oBAC1B,uCACK,SAAS,KACZ,YAAY,EAAE,IAAI,CAAC,mBAAmB,CACpC,SAAS,CAAC,YAAY,EACtB,MAAM,CACP,IACD;iBACH;qBAAM;oBACL,OAAO,SAAS,CAAC;iBAClB;YACH;gBACE,OAAO,SAAS,CAAC;SACpB;IACH,CAAC;IAEO,mBAAmB,CACzB,YAA8B,EAC9B,MAAM;QAEN,uCACK,YAAY,KACf,UAAU,EAAE,YAAY,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE,CACpD,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,MAAM,CAAC,CACzC,IACD;IACJ,CAAC;IAEO,gBAAgB,CACtB,UAAwC,EACxC,MAAM;QAEN,OAAO,UAAU,CAAC,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE;YAClC,QAAQ,SAAS,CAAC,IAAI,EAAE;gBACtB,KAAK,OAAO;oBACV,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;oBAClD,OAAO,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;gBAC9C;oBACE,OAAO,SAAS,CAAC;aACpB;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,wBAAwB,CAAC,QAAgC,EAAE,MAAM;QACvE,MAAM,GAAG,mCACJ,QAAQ,KACX,IAAI,EAAE,GAAG,CAAC,IAAI,CAAC,MAAM,GAAG,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,GAC7C,CAAC;QAEF,IAAI,QAAQ,CAAC,YAAY,EAAE;YACzB,GAAG,CAAC,YAAY,GAAG,IAAI,CAAC,mBAAmB,CACzC,QAAQ,CAAC,YAAY,EACrB,MAAM,CACP,CAAC;SACH;QAED,OAAO,GAAG,CAAC;IACb,CAAC;IAEO,yBAAyB,CAC/B,SAAmC,EACnC,MAAM;QAEN,OAAO,SAAS,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAChC,IAAI,CAAC,wBAAwB,CAAC,QAAQ,EAAE,MAAM,CAAC,CAChD,CAAC;IACJ,CAAC;IAEO,KAAK;QACX,IAAI,mBAAmB,GAA6B,EAAE,CAAC;QACvD,IAAI,UAAU,GAAoB,EAAE,CAAC;QACrC,MAAM,eAAe,GAAG,EAAE,CAAC;QAC3B,IAAI,eAAe,GAA6B,EAAE,CAAC;QAEnD,MAAM,QAAQ,GAAa,EAAE,CAAC;QAE9B,yDAAyD;QACzD,+BAA+B;QAC/B,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,UAAU,EAAE,GAAG,EAAE,EAAE;YAC3C,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,GAAG,UAAU,CAAC,cAAc,CAAC;YAE1D,MAAM,iBAAiB,GAAG,WAAW,CAAC,QAAQ,CAAC,CAAC;YAEhD,wDAAwD;YACxD,IAAI,MAAM,GAAG,OAAO,GAAG,GAAG,CAAC;YAC3B,IAAI,iBAAiB,CAAC,IAAI,EAAE;gBAC1B,MAAM,IAAI,iBAAiB,CAAC,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC;aAC9C;YAED,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAEtB,6BAA6B;YAC7B,mBAAmB,GAAG;gBACpB,GAAG,mBAAmB;gBACtB,GAAG,IAAI,CAAC,yBAAyB,CAC/B,iBAAiB,CAAC,mBAAmB,EACrC,MAAM,CACP;aACF,CAAC;YAEF,8BAA8B;YAC9B,UAAU,GAAG;gBACX,GAAG,UAAU;gBACb,GAAG,IAAI,CAAC,gBAAgB,CACtB,iBAAiB,CAAC,YAAY,CAAC,UAAU,EACzC,MAAM,CACP;aACF,CAAC;YAEF,kCAAkC;YAElC,6BAA6B;YAC7B,KAAK,MAAM,IAAI,IAAI,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE;gBACzC,eAAe,CAAC,MAAM,GAAG,IAAI,CAAC,GAAG,SAAS,CAAC,IAAI,CAAC,CAAC;aAClD;YAED,6BAA6B;YAC7B,MAAM,SAAS,GAAG,YAAY,CAAC,QAAQ,CAAC,CAAC;YACzC,eAAe,GAAG;gBAChB,GAAG,eAAe;gBAClB,GAAG,IAAI,CAAC,yBAAyB,CAAC,SAAS,EAAE,MAAM,CAAC;aACrD,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,MAAM,cAAc,GAAiB,MAAM,CAAC,SAAS,CAAC,mBAAmB,CAAC,CAAC;QAC3E,MAAM,YAAY,GAAG,WAAW,CAAC,cAAc,CAAC,CAAC;QACjD,iCAAiC;QACjC,YAAY,CAAC,YAAY,CAAC,UAAU,GAAG,UAAU,CAAC;QAClD,uBAAuB;QACvB,4CAA4C;QAC3C,YAAoB,CAAC,mBAAmB,GAAG,mBAAmB,CAAC;QAChE,uBAAuB;QACtB,cAAsB,CAAC,WAAW,GAAG;YACpC,GAAG,cAAc,CAAC,WAAW;YAC7B,GAAG,eAAe;SACnB,CAAC;QAEF,OAAO;YACL,QAAQ,EAAE,cAAc;YACxB,SAAS,EAAE,eAAe;YAC1B,QAAQ;SACT,CAAC;IACJ,CAAC;CACF","sourcesContent":["import {\r\n  ArgumentNode,\r\n  DocumentNode,\r\n  FieldNode,\r\n  FragmentDefinitionNode,\r\n  FragmentSpreadNode,\r\n  SelectionNode,\r\n  SelectionSetNode,\r\n  VariableDefinitionNode,\r\n} from 'graphql';\r\nimport {\r\n  LrBadArgumentException,\r\n  LrBadLogicException,\r\n  LrUnsupportedException,\r\n} from '../../_common/exceptions';\r\nimport { LrMutation } from './lr-mutation';\r\nimport { LrMutationBase } from './lr-mutation-base';\r\nimport { getAliasOrName, getFragments, getMutation } from '../../_common/ast';\r\nimport * as ast from '../../_common/ast';\r\nimport * as lodash from 'lodash';\r\n\r\nconst lrMergedMutationDoc: DocumentNode = {\r\n  kind: 'Document',\r\n  definitions: [\r\n    {\r\n      kind: 'OperationDefinition',\r\n      operation: 'mutation',\r\n      name: {\r\n        kind: 'Name',\r\n        value: 'lrMergedMutation',\r\n      },\r\n      variableDefinitions: [],\r\n      directives: [],\r\n      selectionSet: {\r\n        kind: 'SelectionSet',\r\n        selections: [],\r\n      },\r\n    },\r\n  ],\r\n  // TODO What to do about these? Serialise and reparse?\r\n  // \"loc\": {\r\n  //   \"start\": 0,\r\n  //   \"end\": 204\r\n  // }\r\n};\r\n\r\nexport class LrMergedMutation<T> extends LrMutationBase<T> {\r\n  public readonly descendants: Set<LrMutationBase<any>>;\r\n  protected prefixes: string[];\r\n\r\n  constructor(public readonly lrMutations: LrMutationBase<any>[]) {\r\n    super();\r\n\r\n    const { mutation, variables, prefixes } = this.merge();\r\n    this.mutation = mutation;\r\n    this.variables = variables;\r\n    this.prefixes = prefixes;\r\n    this.descendants = this.getDescendants();\r\n  }\r\n\r\n  static create<T1, T2>(\r\n    lrMutations: [\r\n      LrMutationBase<T1> | LrMergedMutation<T1>,\r\n      LrMutationBase<T2> | LrMergedMutation<T2>\r\n    ]\r\n  ): LrMergedMutation<[T1, T2]>;\r\n\r\n  static create<T1, T2, T3>(\r\n    lrMutations: [\r\n      LrMutationBase<T1> | LrMergedMutation<T1>,\r\n      LrMutationBase<T2> | LrMergedMutation<T2>,\r\n      LrMutationBase<T3> | LrMergedMutation<T3>\r\n    ]\r\n  ): LrMergedMutation<[T1, T2, T3]>;\r\n\r\n  static create<T1, T2, T3, T4>(\r\n    lrMutations: [\r\n      LrMutationBase<T1> | LrMergedMutation<T1>,\r\n      LrMutationBase<T2> | LrMergedMutation<T2>,\r\n      LrMutationBase<T3> | LrMergedMutation<T3>,\r\n      LrMutationBase<T4> | LrMergedMutation<T4>\r\n    ]\r\n  ): LrMergedMutation<[T1, T2, T3, T4]>;\r\n\r\n  static create<T1, T2, T3, T4, T5>(\r\n    lrMutations: [\r\n      LrMutationBase<T1> | LrMergedMutation<T1>,\r\n      LrMutationBase<T2> | LrMergedMutation<T2>,\r\n      LrMutationBase<T3> | LrMergedMutation<T3>,\r\n      LrMutationBase<T4> | LrMergedMutation<T4>,\r\n      LrMutationBase<T5> | LrMergedMutation<T5>\r\n    ]\r\n  ): LrMergedMutation<[T1, T2, T3, T4, T5]>;\r\n\r\n  static create(lrMutations: LrMutationBase<any>[]): LrMergedMutation<any[]>;\r\n\r\n  static create(lrMutations: LrMutationBase<any>[]) {\r\n    return new LrMergedMutation(lrMutations);\r\n  }\r\n\r\n  private getDescendants() {\r\n    const ret = new Set<LrMutationBase<any>>();\r\n\r\n    const addOrThrow = (item) => {\r\n      if (ret.has(item)) {\r\n        throw new LrBadLogicException(\r\n          'Classes that are derived from LrMutationBase can not be used more than once in a merged mutation.'\r\n        );\r\n      }\r\n\r\n      ret.add(item);\r\n    };\r\n\r\n    this.lrMutations.forEach((lrMutation) => {\r\n      if (lrMutation instanceof LrMutation) {\r\n        addOrThrow(lrMutation);\r\n      } else if (lrMutation instanceof LrMergedMutation) {\r\n        lrMutation.descendants.forEach((t) => addOrThrow(t));\r\n      } else {\r\n        throw new LrUnsupportedException(\r\n          `LrMergeMutation can not handle class: ${lrMutation.constructor.name}`\r\n        );\r\n      }\r\n    });\r\n\r\n    return ret;\r\n  }\r\n\r\n  resolve(value: any) {\r\n    // Resolves any promises waiting for the child mutations\r\n    for (let i = 0; i < this.lrMutations.length; ++i) {\r\n      const prefix = this.prefixes[i];\r\n\r\n      // Remove the prefix and resolve child mutation.\r\n      const res: any = {};\r\n      for (const key2 in value) {\r\n        if (key2.startsWith(prefix)) {\r\n          const originalKey = key2.slice(prefix.length);\r\n          res[originalKey] = value[key2];\r\n        }\r\n      }\r\n      this.lrMutations[i].resolve(res);\r\n    }\r\n\r\n    // Resolves to the result of children\r\n    Promise.all(this.lrMutations.map((m) => m.promise)).then(\r\n      (childValues: any) => {\r\n        // Resolves any promises waiting for the current merged mutation\r\n        super.resolve(childValues);\r\n      }\r\n    );\r\n  }\r\n\r\n  reject(reason?: any) {\r\n    super.reject(reason);\r\n    this.lrMutations.forEach((lrMutation) => lrMutation.reject(reason));\r\n  }\r\n\r\n  setExecuted() {\r\n    super.setExecuted();\r\n    this.lrMutations.forEach((lrMutation) => lrMutation.setExecuted());\r\n  }\r\n\r\n  private renameVariableDefinition(varDef: VariableDefinitionNode, prefix) {\r\n    return {\r\n      ...varDef,\r\n      variable: {\r\n        ...varDef.variable,\r\n        name: ast.name(prefix + varDef.variable.name.value),\r\n      },\r\n    };\r\n  }\r\n\r\n  private renameVariableDefinitions(\r\n    varDefs: ReadonlyArray<VariableDefinitionNode>,\r\n    prefix\r\n  ) {\r\n    return varDefs.map((varDef) =>\r\n      this.renameVariableDefinition(varDef, prefix)\r\n    );\r\n  }\r\n\r\n  private renameArgument(arg: ArgumentNode, prefix) {\r\n    if (arg.value.kind !== 'Variable') {\r\n      return arg;\r\n    }\r\n\r\n    return {\r\n      ...arg,\r\n      value: {\r\n        ...arg.value,\r\n        name: ast.name(prefix + arg.value.name.value),\r\n      },\r\n    };\r\n  }\r\n\r\n  private renameField(selection: FieldNode, prefix): FieldNode {\r\n    // Only handling type Field\r\n    if (selection.kind !== 'Field') {\r\n      return selection;\r\n    }\r\n\r\n    const alias = prefix + getAliasOrName(selection);\r\n    const args = selection.arguments.map((arg) =>\r\n      this.renameArgument(arg, prefix)\r\n    );\r\n\r\n    return {\r\n      ...selection,\r\n      alias: {\r\n        kind: 'Name',\r\n        value: alias,\r\n      },\r\n      arguments: args,\r\n    };\r\n  }\r\n\r\n  private renameFragmentSpread(\r\n    selection: FragmentSpreadNode,\r\n    prefix\r\n  ): FragmentSpreadNode {\r\n    return {\r\n      ...selection,\r\n      name: ast.name(prefix + selection.name.value),\r\n    };\r\n  }\r\n\r\n  private processSelection(selection: SelectionNode, prefix): SelectionNode {\r\n    switch (selection.kind) {\r\n      case 'FragmentSpread':\r\n        return this.renameFragmentSpread(selection, prefix);\r\n      case 'Field':\r\n        // Continue to process children for nested selections.\r\n        if (selection.selectionSet) {\r\n          return {\r\n            ...selection,\r\n            selectionSet: this.processSelectionSet(\r\n              selection.selectionSet,\r\n              prefix\r\n            ),\r\n          };\r\n        } else {\r\n          return selection;\r\n        }\r\n      default:\r\n        return selection;\r\n    }\r\n  }\r\n\r\n  private processSelectionSet(\r\n    selectionSet: SelectionSetNode,\r\n    prefix\r\n  ): SelectionSetNode {\r\n    return {\r\n      ...selectionSet,\r\n      selections: selectionSet.selections.map((selection) =>\r\n        this.processSelection(selection, prefix)\r\n      ),\r\n    };\r\n  }\r\n\r\n  private renameSelections(\r\n    selections: ReadonlyArray<SelectionNode>,\r\n    prefix\r\n  ): SelectionNode[] {\r\n    return selections.map((selection) => {\r\n      switch (selection.kind) {\r\n        case 'Field':\r\n          const field = this.renameField(selection, prefix);\r\n          return this.processSelection(field, prefix);\r\n        default:\r\n          return selection;\r\n      }\r\n    });\r\n  }\r\n\r\n  private renameFragmentDefinition(fragment: FragmentDefinitionNode, prefix) {\r\n    const ret = {\r\n      ...fragment,\r\n      name: ast.name(prefix + fragment.name.value),\r\n    };\r\n\r\n    if (fragment.selectionSet) {\r\n      ret.selectionSet = this.processSelectionSet(\r\n        fragment.selectionSet,\r\n        prefix\r\n      );\r\n    }\r\n\r\n    return ret;\r\n  }\r\n\r\n  private renameFragmentDefinitions(\r\n    fragments: FragmentDefinitionNode[],\r\n    prefix\r\n  ) {\r\n    return fragments.map((fragment) =>\r\n      this.renameFragmentDefinition(fragment, prefix)\r\n    );\r\n  }\r\n\r\n  private merge() {\r\n    let variableDefinitions: VariableDefinitionNode[] = [];\r\n    let selections: SelectionNode[] = [];\r\n    const mergedVariables = {};\r\n    let mergedFragments: FragmentDefinitionNode[] = [];\r\n\r\n    const prefixes: string[] = [];\r\n\r\n    // Just wait for everything to resolve because we have to\r\n    // merge the doc synchronously.\r\n    this.lrMutations.forEach((lrMutation, idx) => {\r\n      const { mutation, variables } = lrMutation.lrMutationData;\r\n\r\n      const childMutationNode = getMutation(mutation);\r\n\r\n      // Prefixing all mutation fields so they don't conflict.\r\n      let prefix = `item${idx}_`;\r\n      if (childMutationNode.name) {\r\n        prefix += childMutationNode.name.value + '_';\r\n      }\r\n\r\n      prefixes.push(prefix);\r\n\r\n      // Rename and merge variables\r\n      variableDefinitions = [\r\n        ...variableDefinitions,\r\n        ...this.renameVariableDefinitions(\r\n          childMutationNode.variableDefinitions,\r\n          prefix\r\n        ),\r\n      ];\r\n\r\n      // Rename and merge selections\r\n      selections = [\r\n        ...selections,\r\n        ...this.renameSelections(\r\n          childMutationNode.selectionSet.selections,\r\n          prefix\r\n        ),\r\n      ];\r\n\r\n      // TODO Rename and merge fragments\r\n\r\n      // Rename and merge variables\r\n      for (const key2 of Object.keys(variables)) {\r\n        mergedVariables[prefix + key2] = variables[key2];\r\n      }\r\n\r\n      // Rename and merge fragments\r\n      const fragments = getFragments(mutation);\r\n      mergedFragments = [\r\n        ...mergedFragments,\r\n        ...this.renameFragmentDefinitions(fragments, prefix),\r\n      ];\r\n    });\r\n\r\n    const mergedMutation: DocumentNode = lodash.cloneDeep(lrMergedMutationDoc);\r\n    const mutationNode = getMutation(mergedMutation);\r\n    // Add in the mutation selections\r\n    mutationNode.selectionSet.selections = selections;\r\n    // Add in the variables\r\n    // variableDefinitions is readonly property.\r\n    (mutationNode as any).variableDefinitions = variableDefinitions;\r\n    // Add in the fragments\r\n    (mergedMutation as any).definitions = [\r\n      ...mergedMutation.definitions,\r\n      ...mergedFragments,\r\n    ];\r\n\r\n    return {\r\n      mutation: mergedMutation,\r\n      variables: mergedVariables,\r\n      prefixes,\r\n    };\r\n  }\r\n}\r\n"]}
|