@lifeready/core 1.0.2 → 1.0.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +62 -62
- package/bundles/lifeready-core.umd.js +15445 -15445
- package/bundles/lifeready-core.umd.js.map +1 -1
- package/bundles/lifeready-core.umd.min.js.map +1 -1
- package/esm2015/lib/_common/ast.js +40 -40
- package/esm2015/lib/_common/deferred-promise.js +24 -24
- package/esm2015/lib/_common/exceptions.js +157 -157
- package/esm2015/lib/_common/queries.gql.js +190 -190
- package/esm2015/lib/_common/run-outside-angular.js +79 -79
- package/esm2015/lib/_common/types.js +1 -1
- package/esm2015/lib/_common/utils.js +44 -44
- package/esm2015/lib/api/contact-card.gql.js +79 -79
- package/esm2015/lib/api/contact-card.service.js +154 -154
- package/esm2015/lib/api/contact-card2.gql.js +60 -60
- package/esm2015/lib/api/contact-card2.service.js +103 -103
- package/esm2015/lib/api/file.service.js +74 -74
- package/esm2015/lib/api/item2.gql.js +110 -110
- package/esm2015/lib/api/item2.service.js +311 -311
- package/esm2015/lib/api/key-exchange.gql.js +188 -188
- package/esm2015/lib/api/key-exchange.service.js +442 -442
- package/esm2015/lib/api/key-exchange.types.js +18 -18
- package/esm2015/lib/api/key-exchange2.gql.js +171 -171
- package/esm2015/lib/api/key-exchange2.service.js +479 -479
- package/esm2015/lib/api/lock.gql.js +40 -40
- package/esm2015/lib/api/lock.service.js +64 -64
- package/esm2015/lib/api/lr-apollo.service.js +46 -46
- package/esm2015/lib/api/lr-graphql/index.js +6 -6
- package/esm2015/lib/api/lr-graphql/lr-graphql.service.js +155 -155
- package/esm2015/lib/api/lr-graphql/lr-merged-mutation.js +213 -213
- package/esm2015/lib/api/lr-graphql/lr-mutation-base.js +51 -51
- package/esm2015/lib/api/lr-graphql/lr-mutation.js +48 -48
- package/esm2015/lib/api/lr-graphql/lr.service.js +18 -18
- package/esm2015/lib/api/message.service.js +138 -138
- package/esm2015/lib/api/persist.service.js +181 -181
- package/esm2015/lib/api/query-processor/common-processors.service.js +93 -93
- package/esm2015/lib/api/query-processor/index.js +3 -3
- package/esm2015/lib/api/query-processor/query-processor.service.js +192 -192
- package/esm2015/lib/api/query-processor/tp-password-reset-processor.service.js +109 -109
- package/esm2015/lib/api/shared-contact-card.service.js +119 -119
- package/esm2015/lib/api/shared-contact-card2.gql.js +41 -41
- package/esm2015/lib/api/shared-contact-card2.service.js +117 -117
- package/esm2015/lib/api/time.service.js +146 -146
- package/esm2015/lib/api/types/graphql.types.js +7 -7
- package/esm2015/lib/api/types/index.js +3 -3
- package/esm2015/lib/api/types/lr-graphql.types.js +71 -71
- package/esm2015/lib/auth/auth.config.js +57 -57
- package/esm2015/lib/auth/auth.gql.js +48 -48
- package/esm2015/lib/auth/auth.types.js +27 -27
- package/esm2015/lib/auth/idle.service.js +168 -168
- package/esm2015/lib/auth/idle.types.js +7 -7
- package/esm2015/lib/auth/lbop.service.js +355 -355
- package/esm2015/lib/auth/life-ready-auth.service.js +500 -500
- package/esm2015/lib/auth/password.service.js +320 -320
- package/esm2015/lib/auth/register.service.js +172 -172
- package/esm2015/lib/auth/two-factor.service.js +74 -74
- package/esm2015/lib/category/category-meta.service.js +99 -99
- package/esm2015/lib/category/category.gql.js +406 -406
- package/esm2015/lib/category/category.service.js +390 -390
- package/esm2015/lib/category/category.types.js +29 -29
- package/esm2015/lib/cryptography/cryptography.types.js +11 -11
- package/esm2015/lib/cryptography/encryption.service.js +189 -189
- package/esm2015/lib/cryptography/key-factory.service.js +237 -237
- package/esm2015/lib/cryptography/key-graph.service.js +280 -280
- package/esm2015/lib/cryptography/key-meta.service.js +200 -200
- package/esm2015/lib/cryptography/key.service.js +124 -124
- package/esm2015/lib/cryptography/slip39.service.js +169 -169
- package/esm2015/lib/cryptography/web-crypto.service.js +29 -29
- package/esm2015/lib/life-ready.config.js +84 -84
- package/esm2015/lib/life-ready.module.js +74 -74
- package/esm2015/lib/plan/plan.gql.js +123 -123
- package/esm2015/lib/plan/plan.service.js +149 -149
- package/esm2015/lib/plan/plan.types.js +11 -11
- package/esm2015/lib/record/record-attachment.service.js +101 -101
- package/esm2015/lib/record/record.gql.js +179 -179
- package/esm2015/lib/record/record.service.js +206 -206
- package/esm2015/lib/record/record.types.js +15 -15
- package/esm2015/lib/record-type/record-type.service.js +75 -75
- package/esm2015/lib/record-type/record-type.types.js +28 -28
- package/esm2015/lib/scenario/approvals/scenario-approval.gql.js +105 -105
- package/esm2015/lib/scenario/approvals/scenario-approval.types.js +1 -1
- package/esm2015/lib/scenario/approvals/scenario-approver.service.js +300 -300
- package/esm2015/lib/scenario/claimants/scenario-claimant.gql.js +52 -52
- package/esm2015/lib/scenario/claimants/scenario-claimant.service.js +97 -97
- package/esm2015/lib/scenario/claimants/scenario-claimant.types.js +1 -1
- package/esm2015/lib/scenario/receivers/scenario-receiver.gql.js +150 -150
- package/esm2015/lib/scenario/receivers/scenario-receiver.service.js +229 -229
- package/esm2015/lib/scenario/receivers/scenario-receiver.types.js +1 -1
- package/esm2015/lib/scenario/scenario-setup.service.js +269 -269
- package/esm2015/lib/scenario/scenario.gql.js +368 -368
- package/esm2015/lib/scenario/scenario.service.js +611 -611
- package/esm2015/lib/scenario/scenario.types.js +64 -64
- package/esm2015/lib/search/search.gql.js +62 -62
- package/esm2015/lib/search/search.service.js +156 -156
- package/esm2015/lib/search/search.types.js +6 -6
- package/esm2015/lib/trusted-parties/tp-password-reset-request.service.js +112 -112
- package/esm2015/lib/trusted-parties/tp-password-reset-user.service.js +129 -129
- package/esm2015/lib/trusted-parties/tp-password-reset.constants.js +4 -4
- package/esm2015/lib/trusted-parties/tp-password-reset.gql.js +232 -232
- package/esm2015/lib/trusted-parties/tp-password-reset.service.js +299 -299
- package/esm2015/lib/trusted-parties/trusted-party.gql.js +148 -148
- package/esm2015/lib/trusted-parties/trusted-party.service.js +326 -326
- package/esm2015/lib/trusted-parties/trusted-party.types.js +41 -41
- package/esm2015/lib/trusted-parties/trusted-party2.gql.js +87 -87
- package/esm2015/lib/trusted-parties/trusted-party2.service.js +215 -215
- package/esm2015/lib/users/profile-details.service.js +214 -214
- package/esm2015/lib/users/profile.gql.js +97 -97
- package/esm2015/lib/users/profile.service.js +169 -169
- package/esm2015/lib/users/profile.types.js +34 -34
- package/esm2015/lib/users/user.gql.js +60 -60
- package/esm2015/lib/users/user.service.js +79 -79
- package/esm2015/lib/users/user.types.js +5 -5
- package/esm2015/lifeready-core.js +10 -10
- package/esm2015/public-api.js +81 -81
- package/fesm2015/lifeready-core.js +13088 -13088
- package/fesm2015/lifeready-core.js.map +1 -1
- package/lib/_common/ast.d.ts +11 -11
- package/lib/_common/deferred-promise.d.ts +12 -12
- package/lib/_common/exceptions.d.ts +109 -109
- package/lib/_common/queries.gql.d.ts +10 -10
- package/lib/_common/run-outside-angular.d.ts +14 -14
- package/lib/_common/types.d.ts +10 -10
- package/lib/_common/utils.d.ts +3 -3
- package/lib/api/contact-card.gql.d.ts +7 -7
- package/lib/api/contact-card.service.d.ts +52 -52
- package/lib/api/contact-card2.gql.d.ts +34 -34
- package/lib/api/contact-card2.service.d.ts +49 -49
- package/lib/api/file.service.d.ts +18 -18
- package/lib/api/item2.gql.d.ts +96 -96
- package/lib/api/item2.service.d.ts +177 -177
- package/lib/api/key-exchange.gql.d.ts +9 -9
- package/lib/api/key-exchange.service.d.ts +39 -39
- package/lib/api/key-exchange.types.d.ts +196 -196
- package/lib/api/key-exchange2.gql.d.ts +125 -125
- package/lib/api/key-exchange2.service.d.ts +187 -187
- package/lib/api/lock.gql.d.ts +27 -27
- package/lib/api/lock.service.d.ts +25 -25
- package/lib/api/lr-apollo.service.d.ts +15 -15
- package/lib/api/lr-graphql/index.d.ts +5 -5
- package/lib/api/lr-graphql/lr-graphql.service.d.ts +60 -60
- package/lib/api/lr-graphql/lr-merged-mutation.d.ts +27 -27
- package/lib/api/lr-graphql/lr-mutation-base.d.ts +28 -28
- package/lib/api/lr-graphql/lr-mutation.d.ts +8 -8
- package/lib/api/lr-graphql/lr.service.d.ts +9 -9
- package/lib/api/message.service.d.ts +58 -58
- package/lib/api/persist.service.d.ts +31 -31
- package/lib/api/query-processor/common-processors.service.d.ts +36 -36
- package/lib/api/query-processor/index.d.ts +2 -2
- package/lib/api/query-processor/query-processor.service.d.ts +18 -18
- package/lib/api/query-processor/tp-password-reset-processor.service.d.ts +15 -15
- package/lib/api/shared-contact-card.service.d.ts +33 -33
- package/lib/api/shared-contact-card2.gql.d.ts +36 -36
- package/lib/api/shared-contact-card2.service.d.ts +45 -45
- package/lib/api/time.service.d.ts +16 -16
- package/lib/api/types/graphql.types.d.ts +29 -29
- package/lib/api/types/index.d.ts +2 -2
- package/lib/api/types/lr-graphql.types.d.ts +385 -385
- package/lib/auth/auth.config.d.ts +5 -5
- package/lib/auth/auth.gql.d.ts +15 -15
- package/lib/auth/auth.types.d.ts +66 -66
- package/lib/auth/idle.service.d.ts +40 -40
- package/lib/auth/idle.types.d.ts +10 -10
- package/lib/auth/lbop.service.d.ts +91 -91
- package/lib/auth/life-ready-auth.service.d.ts +59 -59
- package/lib/auth/password.service.d.ts +78 -78
- package/lib/auth/register.service.d.ts +25 -25
- package/lib/auth/two-factor.service.d.ts +15 -15
- package/lib/category/category-meta.service.d.ts +23 -23
- package/lib/category/category.gql.d.ts +45 -45
- package/lib/category/category.service.d.ts +67 -67
- package/lib/category/category.types.d.ts +79 -79
- package/lib/cryptography/cryptography.types.d.ts +83 -83
- package/lib/cryptography/encryption.service.d.ts +41 -41
- package/lib/cryptography/key-factory.service.d.ts +38 -38
- package/lib/cryptography/key-graph.service.d.ts +33 -33
- package/lib/cryptography/key-meta.service.d.ts +44 -44
- package/lib/cryptography/key.service.d.ts +36 -36
- package/lib/cryptography/slip39.service.d.ts +43 -43
- package/lib/cryptography/web-crypto.service.d.ts +5 -5
- package/lib/life-ready.config.d.ts +14 -14
- package/lib/life-ready.module.d.ts +5 -5
- package/lib/plan/plan.gql.d.ts +11 -11
- package/lib/plan/plan.service.d.ts +33 -33
- package/lib/plan/plan.types.d.ts +31 -31
- package/lib/record/record-attachment.service.d.ts +16 -16
- package/lib/record/record.gql.d.ts +14 -14
- package/lib/record/record.service.d.ts +25 -25
- package/lib/record/record.types.d.ts +57 -57
- package/lib/record-type/record-type.service.d.ts +11 -11
- package/lib/record-type/record-type.types.d.ts +50 -50
- package/lib/scenario/approvals/scenario-approval.gql.d.ts +7 -7
- package/lib/scenario/approvals/scenario-approval.types.d.ts +63 -63
- package/lib/scenario/approvals/scenario-approver.service.d.ts +32 -32
- package/lib/scenario/claimants/scenario-claimant.gql.d.ts +5 -5
- package/lib/scenario/claimants/scenario-claimant.service.d.ts +17 -17
- package/lib/scenario/claimants/scenario-claimant.types.d.ts +18 -18
- package/lib/scenario/receivers/scenario-receiver.gql.d.ts +8 -8
- package/lib/scenario/receivers/scenario-receiver.service.d.ts +30 -30
- package/lib/scenario/receivers/scenario-receiver.types.d.ts +54 -54
- package/lib/scenario/scenario-setup.service.d.ts +22 -22
- package/lib/scenario/scenario.gql.d.ts +34 -34
- package/lib/scenario/scenario.service.d.ts +58 -58
- package/lib/scenario/scenario.types.d.ts +217 -217
- package/lib/search/search.gql.d.ts +1 -1
- package/lib/search/search.service.d.ts +25 -25
- package/lib/search/search.types.d.ts +20 -20
- package/lib/trusted-parties/tp-password-reset-request.service.d.ts +20 -20
- package/lib/trusted-parties/tp-password-reset-user.service.d.ts +35 -35
- package/lib/trusted-parties/tp-password-reset.constants.d.ts +3 -3
- package/lib/trusted-parties/tp-password-reset.gql.d.ts +218 -218
- package/lib/trusted-parties/tp-password-reset.service.d.ts +130 -130
- package/lib/trusted-parties/trusted-party.gql.d.ts +9 -9
- package/lib/trusted-parties/trusted-party.service.d.ts +44 -44
- package/lib/trusted-parties/trusted-party.types.d.ts +102 -102
- package/lib/trusted-parties/trusted-party2.gql.d.ts +79 -79
- package/lib/trusted-parties/trusted-party2.service.d.ts +114 -114
- package/lib/users/profile-details.service.d.ts +21 -21
- package/lib/users/profile.gql.d.ts +11 -11
- package/lib/users/profile.service.d.ts +35 -35
- package/lib/users/profile.types.d.ts +96 -96
- package/lib/users/user.gql.d.ts +9 -9
- package/lib/users/user.service.d.ts +12 -12
- package/lib/users/user.types.d.ts +23 -23
- package/lifeready-core.d.ts +9 -9
- package/package.json +1 -1
- package/public-api.d.ts +77 -77
|
@@ -1,51 +1,51 @@
|
|
|
1
|
-
import gql from 'graphql-tag';
|
|
2
|
-
import { getQuery } from '../../_common/ast';
|
|
3
|
-
import { DeferredPromise } from '../../_common/deferred-promise';
|
|
4
|
-
import { LrBadStateException } from '../../_common/exceptions';
|
|
5
|
-
export const fragmentSpreadAstSelection = getQuery(gql `
|
|
6
|
-
query {
|
|
7
|
-
...FragmentName
|
|
8
|
-
}
|
|
9
|
-
`).selectionSet.selections[0];
|
|
10
|
-
// const fragmentSpreadAstSelection = () =>
|
|
11
|
-
// lodash.deepClone(_fragmentSpreadAstSelection) as FragmentSpreadNode;
|
|
12
|
-
/**
|
|
13
|
-
* DECISION: LrMutationBase does not provide a convenience method to call lrGraphQL.lrMutate()
|
|
14
|
-
* because this class could be made independent of what lib is used to call the API. If we
|
|
15
|
-
* provided a configurable call back to make the API call, then the typing for that callback
|
|
16
|
-
* needs to be known. But since the API lib (eg. Apollo) has it's own unique return type, so
|
|
17
|
-
* it's not possible to do in general.
|
|
18
|
-
*/
|
|
19
|
-
export class LrMutationBase {
|
|
20
|
-
constructor() {
|
|
21
|
-
/* tslint:disable:variable-name */
|
|
22
|
-
this._executed = false;
|
|
23
|
-
// protected promises: DeferredPromise<T>[] = [];
|
|
24
|
-
this.deferredPromise = new DeferredPromise();
|
|
25
|
-
}
|
|
26
|
-
get promise() {
|
|
27
|
-
return this.deferredPromise.promise;
|
|
28
|
-
}
|
|
29
|
-
resolve(value) {
|
|
30
|
-
this.deferredPromise.resolve(value);
|
|
31
|
-
}
|
|
32
|
-
reject(reason) {
|
|
33
|
-
this.deferredPromise.reject(reason);
|
|
34
|
-
}
|
|
35
|
-
get lrMutationData() {
|
|
36
|
-
return {
|
|
37
|
-
mutation: this.mutation,
|
|
38
|
-
variables: this.variables,
|
|
39
|
-
};
|
|
40
|
-
}
|
|
41
|
-
get executed() {
|
|
42
|
-
return this._executed;
|
|
43
|
-
}
|
|
44
|
-
setExecuted() {
|
|
45
|
-
if (this._executed) {
|
|
46
|
-
throw new LrBadStateException('Already executed');
|
|
47
|
-
}
|
|
48
|
-
this._executed = true;
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import gql from 'graphql-tag';
|
|
2
|
+
import { getQuery } from '../../_common/ast';
|
|
3
|
+
import { DeferredPromise } from '../../_common/deferred-promise';
|
|
4
|
+
import { LrBadStateException } from '../../_common/exceptions';
|
|
5
|
+
export const fragmentSpreadAstSelection = getQuery(gql `
|
|
6
|
+
query {
|
|
7
|
+
...FragmentName
|
|
8
|
+
}
|
|
9
|
+
`).selectionSet.selections[0];
|
|
10
|
+
// const fragmentSpreadAstSelection = () =>
|
|
11
|
+
// lodash.deepClone(_fragmentSpreadAstSelection) as FragmentSpreadNode;
|
|
12
|
+
/**
|
|
13
|
+
* DECISION: LrMutationBase does not provide a convenience method to call lrGraphQL.lrMutate()
|
|
14
|
+
* because this class could be made independent of what lib is used to call the API. If we
|
|
15
|
+
* provided a configurable call back to make the API call, then the typing for that callback
|
|
16
|
+
* needs to be known. But since the API lib (eg. Apollo) has it's own unique return type, so
|
|
17
|
+
* it's not possible to do in general.
|
|
18
|
+
*/
|
|
19
|
+
export class LrMutationBase {
|
|
20
|
+
constructor() {
|
|
21
|
+
/* tslint:disable:variable-name */
|
|
22
|
+
this._executed = false;
|
|
23
|
+
// protected promises: DeferredPromise<T>[] = [];
|
|
24
|
+
this.deferredPromise = new DeferredPromise();
|
|
25
|
+
}
|
|
26
|
+
get promise() {
|
|
27
|
+
return this.deferredPromise.promise;
|
|
28
|
+
}
|
|
29
|
+
resolve(value) {
|
|
30
|
+
this.deferredPromise.resolve(value);
|
|
31
|
+
}
|
|
32
|
+
reject(reason) {
|
|
33
|
+
this.deferredPromise.reject(reason);
|
|
34
|
+
}
|
|
35
|
+
get lrMutationData() {
|
|
36
|
+
return {
|
|
37
|
+
mutation: this.mutation,
|
|
38
|
+
variables: this.variables,
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
get executed() {
|
|
42
|
+
return this._executed;
|
|
43
|
+
}
|
|
44
|
+
setExecuted() {
|
|
45
|
+
if (this._executed) {
|
|
46
|
+
throw new LrBadStateException('Already executed');
|
|
47
|
+
}
|
|
48
|
+
this._executed = true;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibHItbXV0YXRpb24tYmFzZS5qcyIsInNvdXJjZVJvb3QiOiJDOi9Qcm9qZWN0cy9uZXdyZXBvL2tjLWNsaWVudC9wcm9qZWN0cy9jb3JlL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9hcGkvbHItZ3JhcGhxbC9sci1tdXRhdGlvbi1iYXNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sR0FBRyxNQUFNLGFBQWEsQ0FBQztBQUM5QixPQUFPLEVBQUUsUUFBUSxFQUFxQixNQUFNLG1CQUFtQixDQUFDO0FBQ2hFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNqRSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQU8vRCxNQUFNLENBQUMsTUFBTSwwQkFBMEIsR0FBRyxRQUFRLENBQUMsR0FBRyxDQUFBOzs7O0NBSXJELENBQUMsQ0FBQyxZQUFZLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBdUIsQ0FBQztBQUVwRCwyQ0FBMkM7QUFDM0MseUVBQXlFO0FBRXpFOzs7Ozs7R0FNRztBQUNILE1BQU0sT0FBZ0IsY0FBYztJQUFwQztRQUdFLGtDQUFrQztRQUN4QixjQUFTLEdBQUcsS0FBSyxDQUFDO1FBRTVCLGlEQUFpRDtRQUNqQyxvQkFBZSxHQUFHLElBQUksZUFBZSxFQUFLLENBQUM7SUErQjdELENBQUM7SUE3QkMsSUFBSSxPQUFPO1FBQ1QsT0FBTyxJQUFJLENBQUMsZUFBZSxDQUFDLE9BQU8sQ0FBQztJQUN0QyxDQUFDO0lBRUQsT0FBTyxDQUFDLEtBQVE7UUFDZCxJQUFJLENBQUMsZUFBZSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUN0QyxDQUFDO0lBRUQsTUFBTSxDQUFDLE1BQVk7UUFDakIsSUFBSSxDQUFDLGVBQWUsQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDdEMsQ0FBQztJQUVELElBQUksY0FBYztRQUNoQixPQUFPO1lBQ0wsUUFBUSxFQUFFLElBQUksQ0FBQyxRQUFRO1lBQ3ZCLFNBQVMsRUFBRSxJQUFJLENBQUMsU0FBUztTQUMxQixDQUFDO0lBQ0osQ0FBQztJQUVELElBQUksUUFBUTtRQUNWLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQztJQUN4QixDQUFDO0lBRUQsV0FBVztRQUNULElBQUksSUFBSSxDQUFDLFNBQVMsRUFBRTtZQUNsQixNQUFNLElBQUksbUJBQW1CLENBQUMsa0JBQWtCLENBQUMsQ0FBQztTQUNuRDtRQUNELElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDO0lBQ3hCLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE9wZXJhdGlvblZhcmlhYmxlcyB9IGZyb20gJ0BhcG9sbG8vY2xpZW50L2NvcmUnO1xyXG5pbXBvcnQgeyBGcmFnbWVudFNwcmVhZE5vZGUgfSBmcm9tICdncmFwaHFsJztcclxuaW1wb3J0IGdxbCBmcm9tICdncmFwaHFsLXRhZyc7XHJcbmltcG9ydCB7IGdldFF1ZXJ5LCBUeXBlZERvY3VtZW50Tm9kZSB9IGZyb20gJy4uLy4uL19jb21tb24vYXN0JztcclxuaW1wb3J0IHsgRGVmZXJyZWRQcm9taXNlIH0gZnJvbSAnLi4vLi4vX2NvbW1vbi9kZWZlcnJlZC1wcm9taXNlJztcclxuaW1wb3J0IHsgTHJCYWRTdGF0ZUV4Y2VwdGlvbiB9IGZyb20gJy4uLy4uL19jb21tb24vZXhjZXB0aW9ucyc7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIExyTXV0YXRpb25EYXRhPFQsIFRWYXJpYWJsZXMgPSBPcGVyYXRpb25WYXJpYWJsZXM+IHtcclxuICBtdXRhdGlvbjogVHlwZWREb2N1bWVudE5vZGU8VD47XHJcbiAgdmFyaWFibGVzPzogVFZhcmlhYmxlcztcclxufVxyXG5cclxuZXhwb3J0IGNvbnN0IGZyYWdtZW50U3ByZWFkQXN0U2VsZWN0aW9uID0gZ2V0UXVlcnkoZ3FsYFxyXG4gIHF1ZXJ5IHtcclxuICAgIC4uLkZyYWdtZW50TmFtZVxyXG4gIH1cclxuYCkuc2VsZWN0aW9uU2V0LnNlbGVjdGlvbnNbMF0gYXMgRnJhZ21lbnRTcHJlYWROb2RlO1xyXG5cclxuLy8gY29uc3QgZnJhZ21lbnRTcHJlYWRBc3RTZWxlY3Rpb24gPSAoKSA9PlxyXG4vLyAgIGxvZGFzaC5kZWVwQ2xvbmUoX2ZyYWdtZW50U3ByZWFkQXN0U2VsZWN0aW9uKSBhcyBGcmFnbWVudFNwcmVhZE5vZGU7XHJcblxyXG4vKipcclxuICogREVDSVNJT046IExyTXV0YXRpb25CYXNlIGRvZXMgbm90IHByb3ZpZGUgYSBjb252ZW5pZW5jZSBtZXRob2QgdG8gY2FsbCBsckdyYXBoUUwubHJNdXRhdGUoKVxyXG4gKiBiZWNhdXNlIHRoaXMgY2xhc3MgY291bGQgYmUgbWFkZSBpbmRlcGVuZGVudCBvZiB3aGF0IGxpYiBpcyB1c2VkIHRvIGNhbGwgdGhlIEFQSS4gSWYgd2VcclxuICogcHJvdmlkZWQgYSBjb25maWd1cmFibGUgY2FsbCBiYWNrIHRvIG1ha2UgdGhlIEFQSSBjYWxsLCB0aGVuIHRoZSB0eXBpbmcgZm9yIHRoYXQgY2FsbGJhY2tcclxuICogbmVlZHMgdG8gYmUga25vd24uIEJ1dCBzaW5jZSB0aGUgQVBJIGxpYiAoZWcuIEFwb2xsbykgaGFzIGl0J3Mgb3duIHVuaXF1ZSByZXR1cm4gdHlwZSwgc29cclxuICogaXQncyBub3QgcG9zc2libGUgdG8gZG8gaW4gZ2VuZXJhbC5cclxuICovXHJcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBMck11dGF0aW9uQmFzZTxULCBUVmFyaWFibGVzID0gT3BlcmF0aW9uVmFyaWFibGVzPiB7XHJcbiAgcHJvdGVjdGVkIG11dGF0aW9uOiBUeXBlZERvY3VtZW50Tm9kZTxUPjtcclxuICBwcm90ZWN0ZWQgdmFyaWFibGVzPzogVFZhcmlhYmxlcztcclxuICAvKiB0c2xpbnQ6ZGlzYWJsZTp2YXJpYWJsZS1uYW1lICovXHJcbiAgcHJvdGVjdGVkIF9leGVjdXRlZCA9IGZhbHNlO1xyXG5cclxuICAvLyBwcm90ZWN0ZWQgcHJvbWlzZXM6IERlZmVycmVkUHJvbWlzZTxUPltdID0gW107XHJcbiAgcHVibGljIHJlYWRvbmx5IGRlZmVycmVkUHJvbWlzZSA9IG5ldyBEZWZlcnJlZFByb21pc2U8VD4oKTtcclxuXHJcbiAgZ2V0IHByb21pc2UoKTogUHJvbWlzZTxUPiB7XHJcbiAgICByZXR1cm4gdGhpcy5kZWZlcnJlZFByb21pc2UucHJvbWlzZTtcclxuICB9XHJcblxyXG4gIHJlc29sdmUodmFsdWU6IFQpIHtcclxuICAgIHRoaXMuZGVmZXJyZWRQcm9taXNlLnJlc29sdmUodmFsdWUpO1xyXG4gIH1cclxuXHJcbiAgcmVqZWN0KHJlYXNvbj86IGFueSkge1xyXG4gICAgdGhpcy5kZWZlcnJlZFByb21pc2UucmVqZWN0KHJlYXNvbik7XHJcbiAgfVxyXG5cclxuICBnZXQgbHJNdXRhdGlvbkRhdGEoKTogTHJNdXRhdGlvbkRhdGE8VCwgVFZhcmlhYmxlcz4ge1xyXG4gICAgcmV0dXJuIHtcclxuICAgICAgbXV0YXRpb246IHRoaXMubXV0YXRpb24sXHJcbiAgICAgIHZhcmlhYmxlczogdGhpcy52YXJpYWJsZXMsXHJcbiAgICB9O1xyXG4gIH1cclxuXHJcbiAgZ2V0IGV4ZWN1dGVkKCkge1xyXG4gICAgcmV0dXJuIHRoaXMuX2V4ZWN1dGVkO1xyXG4gIH1cclxuXHJcbiAgc2V0RXhlY3V0ZWQoKSB7XHJcbiAgICBpZiAodGhpcy5fZXhlY3V0ZWQpIHtcclxuICAgICAgdGhyb3cgbmV3IExyQmFkU3RhdGVFeGNlcHRpb24oJ0FscmVhZHkgZXhlY3V0ZWQnKTtcclxuICAgIH1cclxuICAgIHRoaXMuX2V4ZWN1dGVkID0gdHJ1ZTtcclxuICB9XHJcbn1cclxuIl19
|
|
@@ -1,48 +1,48 @@
|
|
|
1
|
-
import * as lodash from 'lodash';
|
|
2
|
-
import { getAliasOrName, getFragments, getMutation, } from '../../_common/ast';
|
|
3
|
-
import * as ast from '../../_common/ast';
|
|
4
|
-
import { fragmentSpreadAstSelection, LrMutationBase } from './lr-mutation-base';
|
|
5
|
-
export class LrMutation extends LrMutationBase {
|
|
6
|
-
constructor(options) {
|
|
7
|
-
super();
|
|
8
|
-
this.mutation = options.mutation;
|
|
9
|
-
this.variables = options.variables;
|
|
10
|
-
}
|
|
11
|
-
select(fragments) {
|
|
12
|
-
// Don't touch the original
|
|
13
|
-
const mutationDoc = lodash.cloneDeep(this.mutation);
|
|
14
|
-
const mutationNode = getMutation(mutationDoc);
|
|
15
|
-
const fragmentMap = {};
|
|
16
|
-
getFragments(fragments).forEach((fragment) => {
|
|
17
|
-
fragmentMap[fragment.name.value] = fragment;
|
|
18
|
-
});
|
|
19
|
-
const replaceFieldSelection = (selection) => {
|
|
20
|
-
const field = selection;
|
|
21
|
-
const fieldName = getAliasOrName(field);
|
|
22
|
-
const fragment = fragmentMap[fieldName];
|
|
23
|
-
if (!fragment) {
|
|
24
|
-
return;
|
|
25
|
-
}
|
|
26
|
-
// Make the entire selection of the mutation a spread of
|
|
27
|
-
// a fragment using the same name as the mutation field.
|
|
28
|
-
// We will also rename the fragment to the same name.
|
|
29
|
-
field.selectionSet.selections = [
|
|
30
|
-
Object.assign(Object.assign({}, fragmentSpreadAstSelection), { name: ast.name(fieldName) }),
|
|
31
|
-
];
|
|
32
|
-
};
|
|
33
|
-
mutationNode.selectionSet.selections.forEach((selection) => {
|
|
34
|
-
if (selection.kind === 'Field') {
|
|
35
|
-
replaceFieldSelection(selection);
|
|
36
|
-
}
|
|
37
|
-
});
|
|
38
|
-
return new LrMutation({
|
|
39
|
-
mutation: Object.assign(Object.assign({}, mutationDoc), { definitions: [
|
|
40
|
-
// Remove all existing fragments
|
|
41
|
-
...mutationDoc.definitions.filter((def) => def.kind !== 'FragmentDefinition'),
|
|
42
|
-
...fragments.definitions,
|
|
43
|
-
] }),
|
|
44
|
-
variables: this.variables,
|
|
45
|
-
});
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import * as lodash from 'lodash';
|
|
2
|
+
import { getAliasOrName, getFragments, getMutation, } from '../../_common/ast';
|
|
3
|
+
import * as ast from '../../_common/ast';
|
|
4
|
+
import { fragmentSpreadAstSelection, LrMutationBase } from './lr-mutation-base';
|
|
5
|
+
export class LrMutation extends LrMutationBase {
|
|
6
|
+
constructor(options) {
|
|
7
|
+
super();
|
|
8
|
+
this.mutation = options.mutation;
|
|
9
|
+
this.variables = options.variables;
|
|
10
|
+
}
|
|
11
|
+
select(fragments) {
|
|
12
|
+
// Don't touch the original
|
|
13
|
+
const mutationDoc = lodash.cloneDeep(this.mutation);
|
|
14
|
+
const mutationNode = getMutation(mutationDoc);
|
|
15
|
+
const fragmentMap = {};
|
|
16
|
+
getFragments(fragments).forEach((fragment) => {
|
|
17
|
+
fragmentMap[fragment.name.value] = fragment;
|
|
18
|
+
});
|
|
19
|
+
const replaceFieldSelection = (selection) => {
|
|
20
|
+
const field = selection;
|
|
21
|
+
const fieldName = getAliasOrName(field);
|
|
22
|
+
const fragment = fragmentMap[fieldName];
|
|
23
|
+
if (!fragment) {
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
// Make the entire selection of the mutation a spread of
|
|
27
|
+
// a fragment using the same name as the mutation field.
|
|
28
|
+
// We will also rename the fragment to the same name.
|
|
29
|
+
field.selectionSet.selections = [
|
|
30
|
+
Object.assign(Object.assign({}, fragmentSpreadAstSelection), { name: ast.name(fieldName) }),
|
|
31
|
+
];
|
|
32
|
+
};
|
|
33
|
+
mutationNode.selectionSet.selections.forEach((selection) => {
|
|
34
|
+
if (selection.kind === 'Field') {
|
|
35
|
+
replaceFieldSelection(selection);
|
|
36
|
+
}
|
|
37
|
+
});
|
|
38
|
+
return new LrMutation({
|
|
39
|
+
mutation: Object.assign(Object.assign({}, mutationDoc), { definitions: [
|
|
40
|
+
// Remove all existing fragments
|
|
41
|
+
...mutationDoc.definitions.filter((def) => def.kind !== 'FragmentDefinition'),
|
|
42
|
+
...fragments.definitions,
|
|
43
|
+
] }),
|
|
44
|
+
variables: this.variables,
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibHItbXV0YXRpb24uanMiLCJzb3VyY2VSb290IjoiQzovUHJvamVjdHMvbmV3cmVwby9rYy1jbGllbnQvcHJvamVjdHMvY29yZS9zcmMvIiwic291cmNlcyI6WyJsaWIvYXBpL2xyLWdyYXBocWwvbHItbXV0YXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLE1BQU0sTUFBTSxRQUFRLENBQUM7QUFHakMsT0FBTyxFQUNMLGNBQWMsRUFDZCxZQUFZLEVBQ1osV0FBVyxHQUVaLE1BQU0sbUJBQW1CLENBQUM7QUFDM0IsT0FBTyxLQUFLLEdBQUcsTUFBTSxtQkFBbUIsQ0FBQztBQUV6QyxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsY0FBYyxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFFaEYsTUFBTSxPQUFPLFVBR1gsU0FBUSxjQUE2QjtJQUNyQyxZQUFZLE9BQXNDO1FBQ2hELEtBQUssRUFBRSxDQUFDO1FBQ1IsSUFBSSxDQUFDLFFBQVEsR0FBRyxPQUFPLENBQUMsUUFBUSxDQUFDO1FBQ2pDLElBQUksQ0FBQyxTQUFTLEdBQUcsT0FBTyxDQUFDLFNBQVMsQ0FBQztJQUNyQyxDQUFDO0lBRUQsTUFBTSxDQUFVLFNBQXFDO1FBQ25ELDJCQUEyQjtRQUMzQixNQUFNLFdBQVcsR0FBRyxNQUFNLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQWlCLENBQUM7UUFDcEUsTUFBTSxZQUFZLEdBQUcsV0FBVyxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBRTlDLE1BQU0sV0FBVyxHQUFHLEVBQStDLENBQUM7UUFDcEUsWUFBWSxDQUFDLFNBQVMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLFFBQWdDLEVBQUUsRUFBRTtZQUNuRSxXQUFXLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxRQUFRLENBQUM7UUFDOUMsQ0FBQyxDQUFDLENBQUM7UUFFSCxNQUFNLHFCQUFxQixHQUFHLENBQUMsU0FBb0IsRUFBRSxFQUFFO1lBQ3JELE1BQU0sS0FBSyxHQUFHLFNBQXNCLENBQUM7WUFDckMsTUFBTSxTQUFTLEdBQUcsY0FBYyxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQ3hDLE1BQU0sUUFBUSxHQUFHLFdBQVcsQ0FBQyxTQUFTLENBQUMsQ0FBQztZQUV4QyxJQUFJLENBQUMsUUFBUSxFQUFFO2dCQUNiLE9BQU87YUFDUjtZQUVELHdEQUF3RDtZQUN4RCx3REFBd0Q7WUFDeEQscURBQXFEO1lBQ3JELEtBQUssQ0FBQyxZQUFZLENBQUMsVUFBVSxHQUFHO2dEQUV6QiwwQkFBMEIsS0FDN0IsSUFBSSxFQUFFLEdBQUcsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDO2FBRTVCLENBQUM7UUFDSixDQUFDLENBQUM7UUFFRixZQUFZLENBQUMsWUFBWSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsQ0FBQyxTQUFTLEVBQUUsRUFBRTtZQUN6RCxJQUFJLFNBQVMsQ0FBQyxJQUFJLEtBQUssT0FBTyxFQUFFO2dCQUM5QixxQkFBcUIsQ0FBQyxTQUFTLENBQUMsQ0FBQzthQUNsQztRQUNILENBQUMsQ0FBQyxDQUFDO1FBRUgsT0FBTyxJQUFJLFVBQVUsQ0FBQztZQUNwQixRQUFRLEVBQUUsZ0NBQ0wsV0FBVyxLQUNkLFdBQVcsRUFBRTtvQkFDWCxnQ0FBZ0M7b0JBQ2hDLEdBQUcsV0FBVyxDQUFDLFdBQVcsQ0FBQyxNQUFNLENBQy9CLENBQUMsR0FBRyxFQUFFLEVBQUUsQ0FBQyxHQUFHLENBQUMsSUFBSSxLQUFLLG9CQUFvQixDQUMzQztvQkFDRCxHQUFHLFNBQVMsQ0FBQyxXQUFXO2lCQUN6QixHQUM0QjtZQUMvQixTQUFTLEVBQUUsSUFBSSxDQUFDLFNBQVM7U0FDMUIsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgbG9kYXNoIGZyb20gJ2xvZGFzaCc7XHJcbmltcG9ydCB7IE9wZXJhdGlvblZhcmlhYmxlcyB9IGZyb20gJ0BhcG9sbG8vY2xpZW50L2NvcmUnO1xyXG5pbXBvcnQgeyBEb2N1bWVudE5vZGUsIEZpZWxkTm9kZSwgRnJhZ21lbnREZWZpbml0aW9uTm9kZSB9IGZyb20gJ2dyYXBocWwnO1xyXG5pbXBvcnQge1xyXG4gIGdldEFsaWFzT3JOYW1lLFxyXG4gIGdldEZyYWdtZW50cyxcclxuICBnZXRNdXRhdGlvbixcclxuICBUeXBlZERvY3VtZW50Tm9kZSxcclxufSBmcm9tICcuLi8uLi9fY29tbW9uL2FzdCc7XHJcbmltcG9ydCAqIGFzIGFzdCBmcm9tICcuLi8uLi9fY29tbW9uL2FzdCc7XHJcbmltcG9ydCB7IExyTXV0YXRpb25EYXRhIH0gZnJvbSAnLi9sci1tdXRhdGlvbi1iYXNlJztcclxuaW1wb3J0IHsgZnJhZ21lbnRTcHJlYWRBc3RTZWxlY3Rpb24sIExyTXV0YXRpb25CYXNlIH0gZnJvbSAnLi9sci1tdXRhdGlvbi1iYXNlJztcclxuXHJcbmV4cG9ydCBjbGFzcyBMck11dGF0aW9uPFxyXG4gIFQgZXh0ZW5kcyBhbnksXHJcbiAgVFZhcmlhYmxlcyA9IE9wZXJhdGlvblZhcmlhYmxlc1xyXG4+IGV4dGVuZHMgTHJNdXRhdGlvbkJhc2U8VCwgVFZhcmlhYmxlcz4ge1xyXG4gIGNvbnN0cnVjdG9yKG9wdGlvbnM6IExyTXV0YXRpb25EYXRhPFQsIFRWYXJpYWJsZXM+KSB7XHJcbiAgICBzdXBlcigpO1xyXG4gICAgdGhpcy5tdXRhdGlvbiA9IG9wdGlvbnMubXV0YXRpb247XHJcbiAgICB0aGlzLnZhcmlhYmxlcyA9IG9wdGlvbnMudmFyaWFibGVzO1xyXG4gIH1cclxuXHJcbiAgc2VsZWN0PFRSZXN1bHQ+KGZyYWdtZW50czogVHlwZWREb2N1bWVudE5vZGU8VFJlc3VsdD4pIHtcclxuICAgIC8vIERvbid0IHRvdWNoIHRoZSBvcmlnaW5hbFxyXG4gICAgY29uc3QgbXV0YXRpb25Eb2MgPSBsb2Rhc2guY2xvbmVEZWVwKHRoaXMubXV0YXRpb24pIGFzIERvY3VtZW50Tm9kZTtcclxuICAgIGNvbnN0IG11dGF0aW9uTm9kZSA9IGdldE11dGF0aW9uKG11dGF0aW9uRG9jKTtcclxuXHJcbiAgICBjb25zdCBmcmFnbWVudE1hcCA9IHt9IGFzIHsgW2tleTogc3RyaW5nXTogRnJhZ21lbnREZWZpbml0aW9uTm9kZSB9O1xyXG4gICAgZ2V0RnJhZ21lbnRzKGZyYWdtZW50cykuZm9yRWFjaCgoZnJhZ21lbnQ6IEZyYWdtZW50RGVmaW5pdGlvbk5vZGUpID0+IHtcclxuICAgICAgZnJhZ21lbnRNYXBbZnJhZ21lbnQubmFtZS52YWx1ZV0gPSBmcmFnbWVudDtcclxuICAgIH0pO1xyXG5cclxuICAgIGNvbnN0IHJlcGxhY2VGaWVsZFNlbGVjdGlvbiA9IChzZWxlY3Rpb246IEZpZWxkTm9kZSkgPT4ge1xyXG4gICAgICBjb25zdCBmaWVsZCA9IHNlbGVjdGlvbiBhcyBGaWVsZE5vZGU7XHJcbiAgICAgIGNvbnN0IGZpZWxkTmFtZSA9IGdldEFsaWFzT3JOYW1lKGZpZWxkKTtcclxuICAgICAgY29uc3QgZnJhZ21lbnQgPSBmcmFnbWVudE1hcFtmaWVsZE5hbWVdO1xyXG5cclxuICAgICAgaWYgKCFmcmFnbWVudCkge1xyXG4gICAgICAgIHJldHVybjtcclxuICAgICAgfVxyXG5cclxuICAgICAgLy8gTWFrZSB0aGUgZW50aXJlIHNlbGVjdGlvbiBvZiB0aGUgbXV0YXRpb24gYSBzcHJlYWQgb2ZcclxuICAgICAgLy8gYSBmcmFnbWVudCB1c2luZyB0aGUgc2FtZSBuYW1lIGFzIHRoZSBtdXRhdGlvbiBmaWVsZC5cclxuICAgICAgLy8gV2Ugd2lsbCBhbHNvIHJlbmFtZSB0aGUgZnJhZ21lbnQgdG8gdGhlIHNhbWUgbmFtZS5cclxuICAgICAgZmllbGQuc2VsZWN0aW9uU2V0LnNlbGVjdGlvbnMgPSBbXHJcbiAgICAgICAge1xyXG4gICAgICAgICAgLi4uZnJhZ21lbnRTcHJlYWRBc3RTZWxlY3Rpb24sXHJcbiAgICAgICAgICBuYW1lOiBhc3QubmFtZShmaWVsZE5hbWUpLFxyXG4gICAgICAgIH0sXHJcbiAgICAgIF07XHJcbiAgICB9O1xyXG5cclxuICAgIG11dGF0aW9uTm9kZS5zZWxlY3Rpb25TZXQuc2VsZWN0aW9ucy5mb3JFYWNoKChzZWxlY3Rpb24pID0+IHtcclxuICAgICAgaWYgKHNlbGVjdGlvbi5raW5kID09PSAnRmllbGQnKSB7XHJcbiAgICAgICAgcmVwbGFjZUZpZWxkU2VsZWN0aW9uKHNlbGVjdGlvbik7XHJcbiAgICAgIH1cclxuICAgIH0pO1xyXG5cclxuICAgIHJldHVybiBuZXcgTHJNdXRhdGlvbih7XHJcbiAgICAgIG11dGF0aW9uOiB7XHJcbiAgICAgICAgLi4ubXV0YXRpb25Eb2MsXHJcbiAgICAgICAgZGVmaW5pdGlvbnM6IFtcclxuICAgICAgICAgIC8vIFJlbW92ZSBhbGwgZXhpc3RpbmcgZnJhZ21lbnRzXHJcbiAgICAgICAgICAuLi5tdXRhdGlvbkRvYy5kZWZpbml0aW9ucy5maWx0ZXIoXHJcbiAgICAgICAgICAgIChkZWYpID0+IGRlZi5raW5kICE9PSAnRnJhZ21lbnREZWZpbml0aW9uJ1xyXG4gICAgICAgICAgKSxcclxuICAgICAgICAgIC4uLmZyYWdtZW50cy5kZWZpbml0aW9ucyxcclxuICAgICAgICBdLFxyXG4gICAgICB9IGFzIFR5cGVkRG9jdW1lbnROb2RlPFRSZXN1bHQ+LFxyXG4gICAgICB2YXJpYWJsZXM6IHRoaXMudmFyaWFibGVzLFxyXG4gICAgfSk7XHJcbiAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -1,18 +1,18 @@
|
|
|
1
|
-
import { __awaiter } from "tslib";
|
|
2
|
-
import { LrGraphQLService, } from './lr-graphql.service';
|
|
3
|
-
export class LrService {
|
|
4
|
-
constructor(injector) {
|
|
5
|
-
this.lrGraphQL = injector.get(LrGraphQLService);
|
|
6
|
-
}
|
|
7
|
-
mutate(lrMutation, options) {
|
|
8
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
9
|
-
return this.lrGraphQL.lrMutate(lrMutation, options);
|
|
10
|
-
});
|
|
11
|
-
}
|
|
12
|
-
query(options) {
|
|
13
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
14
|
-
return this.lrGraphQL.query(options);
|
|
15
|
-
});
|
|
16
|
-
}
|
|
17
|
-
}
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
2
|
+
import { LrGraphQLService, } from './lr-graphql.service';
|
|
3
|
+
export class LrService {
|
|
4
|
+
constructor(injector) {
|
|
5
|
+
this.lrGraphQL = injector.get(LrGraphQLService);
|
|
6
|
+
}
|
|
7
|
+
mutate(lrMutation, options) {
|
|
8
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
9
|
+
return this.lrGraphQL.lrMutate(lrMutation, options);
|
|
10
|
+
});
|
|
11
|
+
}
|
|
12
|
+
query(options) {
|
|
13
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
14
|
+
return this.lrGraphQL.query(options);
|
|
15
|
+
});
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibHIuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiJDOi9Qcm9qZWN0cy9uZXdyZXBvL2tjLWNsaWVudC9wcm9qZWN0cy9jb3JlL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9hcGkvbHItZ3JhcGhxbC9sci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFDQSxPQUFPLEVBQ0wsZ0JBQWdCLEdBR2pCLE1BQU0sc0JBQXNCLENBQUM7QUFHOUIsTUFBTSxPQUFPLFNBQVM7SUFHcEIsWUFBWSxRQUFrQjtRQUM1QixJQUFJLENBQUMsU0FBUyxHQUFHLFFBQVEsQ0FBQyxHQUFHLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztJQUNsRCxDQUFDO0lBRWUsTUFBTSxDQUNwQixVQUUwQyxFQUMxQyxPQUEwQzs7WUFFMUMsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxVQUFVLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFDdEQsQ0FBQztLQUFBO0lBRWUsS0FBSyxDQUFPLE9BQTZCOztZQUN2RCxPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ3ZDLENBQUM7S0FBQTtDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0b3IgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHtcclxuICBMckdyYXBoUUxTZXJ2aWNlLFxyXG4gIExyTXV0YXRpb25PcHRpb25zLFxyXG4gIExyUXVlcnlPcHRpb25zLFxyXG59IGZyb20gJy4vbHItZ3JhcGhxbC5zZXJ2aWNlJztcclxuaW1wb3J0IHsgTHJNdXRhdGlvbkJhc2UgfSBmcm9tICcuL2xyLW11dGF0aW9uLWJhc2UnO1xyXG5cclxuZXhwb3J0IGNsYXNzIExyU2VydmljZSB7XHJcbiAgcHJvdGVjdGVkIGxyR3JhcGhRTDogTHJHcmFwaFFMU2VydmljZTtcclxuXHJcbiAgY29uc3RydWN0b3IoaW5qZWN0b3I6IEluamVjdG9yKSB7XHJcbiAgICB0aGlzLmxyR3JhcGhRTCA9IGluamVjdG9yLmdldChMckdyYXBoUUxTZXJ2aWNlKTtcclxuICB9XHJcblxyXG4gIHByb3RlY3RlZCBhc3luYyBtdXRhdGU8VCwgVFZhcmlhYmxlcz4oXHJcbiAgICBsck11dGF0aW9uOlxyXG4gICAgICB8IExyTXV0YXRpb25CYXNlPFQsIFRWYXJpYWJsZXM+XHJcbiAgICAgIHwgUHJvbWlzZTxMck11dGF0aW9uQmFzZTxULCBUVmFyaWFibGVzPj4sXHJcbiAgICBvcHRpb25zPzogTHJNdXRhdGlvbk9wdGlvbnM8VCwgVFZhcmlhYmxlcz5cclxuICApIHtcclxuICAgIHJldHVybiB0aGlzLmxyR3JhcGhRTC5sck11dGF0ZShsck11dGF0aW9uLCBvcHRpb25zKTtcclxuICB9XHJcblxyXG4gIHByb3RlY3RlZCBhc3luYyBxdWVyeTxULCBWPihvcHRpb25zOiBMclF1ZXJ5T3B0aW9uczxULCBWPikge1xyXG4gICAgcmV0dXJuIHRoaXMubHJHcmFwaFFMLnF1ZXJ5KG9wdGlvbnMpO1xyXG4gIH1cclxufVxyXG4iXX0=
|
|
@@ -1,138 +1,138 @@
|
|
|
1
|
-
import { __awaiter } from "tslib";
|
|
2
|
-
import { Injectable } from '@angular/core';
|
|
3
|
-
import gql from 'graphql-tag';
|
|
4
|
-
import { EncryptionService } from '../cryptography/encryption.service';
|
|
5
|
-
import { KeyGraphService } from '../cryptography/key-graph.service';
|
|
6
|
-
import { KeyGraphFragment } from '../_common/queries.gql';
|
|
7
|
-
import { KeyExchangeService } from './key-exchange.service';
|
|
8
|
-
import { LrApolloService } from './lr-apollo.service';
|
|
9
|
-
import * as i0 from "@angular/core";
|
|
10
|
-
import * as i1 from "./lr-apollo.service";
|
|
11
|
-
import * as i2 from "../cryptography/key-graph.service";
|
|
12
|
-
import * as i3 from "../cryptography/encryption.service";
|
|
13
|
-
import * as i4 from "./key-exchange.service";
|
|
14
|
-
export const SendMessageMutation = gql `
|
|
15
|
-
mutation SendMessage($input: SendMessageInput!) {
|
|
16
|
-
sendMessage(input: $input) {
|
|
17
|
-
message {
|
|
18
|
-
id
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
}
|
|
22
|
-
`;
|
|
23
|
-
export const MessageQuery = gql `
|
|
24
|
-
query Message($id: LrRelayIdInput!) {
|
|
25
|
-
message(id: $id) {
|
|
26
|
-
id
|
|
27
|
-
sender {
|
|
28
|
-
username
|
|
29
|
-
}
|
|
30
|
-
receiver {
|
|
31
|
-
username
|
|
32
|
-
}
|
|
33
|
-
plainMessage
|
|
34
|
-
signedCipherMessage
|
|
35
|
-
sharedKey {
|
|
36
|
-
id
|
|
37
|
-
}
|
|
38
|
-
senderSigPbk {
|
|
39
|
-
id
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
keyGraph {
|
|
43
|
-
...KeyGraphFragment
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
${KeyGraphFragment}
|
|
47
|
-
`;
|
|
48
|
-
export class MessageService {
|
|
49
|
-
constructor(lrApollo, keyGraph, encryptionService, keyExchangeService) {
|
|
50
|
-
this.lrApollo = lrApollo;
|
|
51
|
-
this.keyGraph = keyGraph;
|
|
52
|
-
this.encryptionService = encryptionService;
|
|
53
|
-
this.keyExchangeService = keyExchangeService;
|
|
54
|
-
this.encrypt = this.encryptionService.encrypt.bind(this.encryptionService);
|
|
55
|
-
this.decrypt = this.encryptionService.decrypt.bind(this.encryptionService);
|
|
56
|
-
this.sign = this.encryptionService.sign.bind(this.encryptionService);
|
|
57
|
-
this.verify = this.encryptionService.verify.bind(this.encryptionService);
|
|
58
|
-
}
|
|
59
|
-
sendMessage({ username, userId, plainMessageJson, plainCipherMessageJson, }) {
|
|
60
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
61
|
-
const userSharedKey = yield this.keyExchangeService.currentUserSharedKey({
|
|
62
|
-
username,
|
|
63
|
-
userId,
|
|
64
|
-
});
|
|
65
|
-
const input = {
|
|
66
|
-
receiverUsername: username,
|
|
67
|
-
receiverId: userId,
|
|
68
|
-
sharedKeyId: userSharedKey.sharedKey.id,
|
|
69
|
-
senderSigPbkId: userSharedKey.userSigPrk.id,
|
|
70
|
-
};
|
|
71
|
-
if (plainCipherMessageJson) {
|
|
72
|
-
const sharedKey = yield this.keyGraph.getJwkKey(userSharedKey.sharedKey.id);
|
|
73
|
-
const cipherMessage = yield this.encrypt(sharedKey, plainCipherMessageJson);
|
|
74
|
-
const senderSigPrk = yield this.keyGraph.getJwkKey(userSharedKey.userSigPrk.id);
|
|
75
|
-
const signedCipherMessage = yield this.sign(senderSigPrk, cipherMessage);
|
|
76
|
-
input.signedCipherMessage = JSON.stringify(signedCipherMessage);
|
|
77
|
-
}
|
|
78
|
-
if (plainMessageJson) {
|
|
79
|
-
input.plainMessage = JSON.stringify(plainMessageJson);
|
|
80
|
-
}
|
|
81
|
-
const res = yield this.lrApollo.query({
|
|
82
|
-
query: SendMessageMutation,
|
|
83
|
-
variables: {
|
|
84
|
-
input,
|
|
85
|
-
},
|
|
86
|
-
});
|
|
87
|
-
return res.sendMessage;
|
|
88
|
-
});
|
|
89
|
-
}
|
|
90
|
-
decryptMessage(message, { sharedKey, senderSigPbk }) {
|
|
91
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
92
|
-
const signedCipherMessage = yield this.verify(senderSigPbk, JSON.parse(message.signedCipherMessage));
|
|
93
|
-
message.plainSignedCipherMessageJson = yield this.decrypt(sharedKey, signedCipherMessage);
|
|
94
|
-
});
|
|
95
|
-
}
|
|
96
|
-
getMessage(id) {
|
|
97
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
98
|
-
const res = yield this.lrApollo.query({
|
|
99
|
-
query: MessageQuery,
|
|
100
|
-
variables: {
|
|
101
|
-
id,
|
|
102
|
-
},
|
|
103
|
-
});
|
|
104
|
-
this.keyGraph.addKeys(res.keyGraph);
|
|
105
|
-
const message = res.message;
|
|
106
|
-
const sharedKey = yield this.keyGraph.getJwkKey(message.sharedKey.id);
|
|
107
|
-
// The sender would be getting the Prk back. The receiver gets the Pbk back.
|
|
108
|
-
// But only the Pbk is needed here to verify signature.
|
|
109
|
-
// So both sender and receiver can access this message.
|
|
110
|
-
const senderSigPbk = yield this.keyGraph.getJwkKey(message.senderSigPbk.id);
|
|
111
|
-
// Test bad signature
|
|
112
|
-
// senderSigPbk = senderSigPbk.toJSON();
|
|
113
|
-
// senderSigPbk.n = "x" + senderSigPbk.n.substring(1);
|
|
114
|
-
// senderSigPbk = await KFS.asKey(senderSigPbk);
|
|
115
|
-
yield this.decryptMessage(message, {
|
|
116
|
-
sharedKey,
|
|
117
|
-
senderSigPbk,
|
|
118
|
-
});
|
|
119
|
-
if (message.plainMessage) {
|
|
120
|
-
message.plainMessageJson = JSON.parse(message.plainMessage);
|
|
121
|
-
}
|
|
122
|
-
return res.message;
|
|
123
|
-
});
|
|
124
|
-
}
|
|
125
|
-
}
|
|
126
|
-
MessageService.ɵprov = i0.ɵɵdefineInjectable({ factory: function MessageService_Factory() { return new MessageService(i0.ɵɵinject(i1.LrApolloService), i0.ɵɵinject(i2.KeyGraphService), i0.ɵɵinject(i3.EncryptionService), i0.ɵɵinject(i4.KeyExchangeService)); }, token: MessageService, providedIn: "root" });
|
|
127
|
-
MessageService.decorators = [
|
|
128
|
-
{ type: Injectable, args: [{
|
|
129
|
-
providedIn: 'root',
|
|
130
|
-
},] }
|
|
131
|
-
];
|
|
132
|
-
MessageService.ctorParameters = () => [
|
|
133
|
-
{ type: LrApolloService },
|
|
134
|
-
{ type: KeyGraphService },
|
|
135
|
-
{ type: EncryptionService },
|
|
136
|
-
{ type: KeyExchangeService }
|
|
137
|
-
];
|
|
138
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"message.service.js","sourceRoot":"/opt/atlassian/pipelines/agent/build/projects/core/src/","sources":["lib/api/message.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport gql from 'graphql-tag';\nimport { JWK } from 'node-jose';\nimport { EncryptionService } from '../cryptography/encryption.service';\nimport { KeyGraphService } from '../cryptography/key-graph.service';\nimport { KeyGraphFragment } from '../_common/queries.gql';\nimport { KeyExchangeService } from './key-exchange.service';\nimport { LrApolloService } from './lr-apollo.service';\nimport { KeyFactoryService as KFS } from '../cryptography/key-factory.service';\n\nexport const SendMessageMutation = gql`\n  mutation SendMessage($input: SendMessageInput!) {\n    sendMessage(input: $input) {\n      message {\n        id\n      }\n    }\n  }\n`;\n\nexport const MessageQuery = gql`\n  query Message($id: LrRelayIdInput!) {\n    message(id: $id) {\n      id\n      sender {\n        username\n      }\n      receiver {\n        username\n      }\n      plainMessage\n      signedCipherMessage\n      sharedKey {\n        id\n      }\n      senderSigPbk {\n        id\n      }\n    }\n    keyGraph {\n      ...KeyGraphFragment\n    }\n  }\n  ${KeyGraphFragment}\n`;\n\nexport interface SendMessage {\n  message: {\n    id: string;\n  };\n}\n\nexport interface SendMessageInput {\n  username?: string;\n  userId?: string;\n  plainMessageJson?: any;\n  plainCipherMessageJson?: any;\n}\n\nexport interface Message {\n  id: string;\n  sender: {\n    id: string;\n    username: string;\n  };\n  receiver: {\n    id: string;\n    username: string;\n  };\n  plainMessage: string;\n  plainMessageJson?: any;\n  signedCipherMessage: string;\n  plainSignedCipherMessageJson?: any;\n  senderSigPbk: {\n    id: string;\n  };\n  sharedKey: {\n    id: string;\n  };\n}\n\ninterface DecryptMessageOptions {\n  sharedKey: JWK.Key;\n  senderSigPbk: JWK.Key;\n}\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class MessageService {\n  private readonly encrypt = this.encryptionService.encrypt.bind(\n    this.encryptionService\n  );\n  private readonly decrypt = this.encryptionService.decrypt.bind(\n    this.encryptionService\n  );\n  private readonly sign = this.encryptionService.sign.bind(\n    this.encryptionService\n  );\n  private readonly verify = this.encryptionService.verify.bind(\n    this.encryptionService\n  );\n\n  constructor(\n    private lrApollo: LrApolloService,\n    private keyGraph: KeyGraphService,\n    private encryptionService: EncryptionService,\n    private keyExchangeService: KeyExchangeService\n  ) {}\n\n  async sendMessage({\n    username,\n    userId,\n    plainMessageJson,\n    plainCipherMessageJson,\n  }: SendMessageInput): Promise<SendMessage> {\n    const userSharedKey = await this.keyExchangeService.currentUserSharedKey({\n      username,\n      userId,\n    });\n\n    const input: any = {\n      receiverUsername: username,\n      receiverId: userId,\n      sharedKeyId: userSharedKey.sharedKey.id,\n      senderSigPbkId: userSharedKey.userSigPrk.id,\n    };\n\n    if (plainCipherMessageJson) {\n      const sharedKey = await this.keyGraph.getJwkKey(\n        userSharedKey.sharedKey.id\n      );\n      const cipherMessage = await this.encrypt(\n        sharedKey,\n        plainCipherMessageJson\n      );\n\n      const senderSigPrk = await this.keyGraph.getJwkKey(\n        userSharedKey.userSigPrk.id\n      );\n      const signedCipherMessage = await this.sign(senderSigPrk, cipherMessage);\n\n      input.signedCipherMessage = JSON.stringify(signedCipherMessage);\n    }\n\n    if (plainMessageJson) {\n      input.plainMessage = JSON.stringify(plainMessageJson);\n    }\n\n    const res = await this.lrApollo.query<any>({\n      query: SendMessageMutation,\n      variables: {\n        input,\n      },\n    });\n\n    return res.sendMessage;\n  }\n\n  async decryptMessage(\n    message: Message,\n    { sharedKey, senderSigPbk }: DecryptMessageOptions\n  ): Promise<void> {\n    const signedCipherMessage = await this.verify(\n      senderSigPbk,\n      JSON.parse(message.signedCipherMessage)\n    );\n\n    message.plainSignedCipherMessageJson = await this.decrypt(\n      sharedKey,\n      signedCipherMessage\n    );\n  }\n\n  async getMessage(id: string): Promise<Message> {\n    const res = await this.lrApollo.query<any>({\n      query: MessageQuery,\n      variables: {\n        id,\n      },\n    });\n\n    this.keyGraph.addKeys(res.keyGraph);\n\n    const message = res.message as Message;\n\n    const sharedKey = await this.keyGraph.getJwkKey(message.sharedKey.id);\n\n    // The sender would be getting the Prk back. The receiver gets the Pbk back.\n    // But only the Pbk is needed here to verify signature.\n    // So both sender and receiver can access this message.\n    const senderSigPbk = await this.keyGraph.getJwkKey(message.senderSigPbk.id);\n\n    // Test bad signature\n    // senderSigPbk = senderSigPbk.toJSON();\n    // senderSigPbk.n = \"x\" + senderSigPbk.n.substring(1);\n    // senderSigPbk = await KFS.asKey(senderSigPbk);\n\n    await this.decryptMessage(message, {\n      sharedKey,\n      senderSigPbk,\n    });\n\n    if (message.plainMessage) {\n      message.plainMessageJson = JSON.parse(message.plainMessage);\n    }\n\n    return res.message;\n  }\n}\n"]}
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
2
|
+
import { Injectable } from '@angular/core';
|
|
3
|
+
import gql from 'graphql-tag';
|
|
4
|
+
import { EncryptionService } from '../cryptography/encryption.service';
|
|
5
|
+
import { KeyGraphService } from '../cryptography/key-graph.service';
|
|
6
|
+
import { KeyGraphFragment } from '../_common/queries.gql';
|
|
7
|
+
import { KeyExchangeService } from './key-exchange.service';
|
|
8
|
+
import { LrApolloService } from './lr-apollo.service';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
import * as i1 from "./lr-apollo.service";
|
|
11
|
+
import * as i2 from "../cryptography/key-graph.service";
|
|
12
|
+
import * as i3 from "../cryptography/encryption.service";
|
|
13
|
+
import * as i4 from "./key-exchange.service";
|
|
14
|
+
export const SendMessageMutation = gql `
|
|
15
|
+
mutation SendMessage($input: SendMessageInput!) {
|
|
16
|
+
sendMessage(input: $input) {
|
|
17
|
+
message {
|
|
18
|
+
id
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
`;
|
|
23
|
+
export const MessageQuery = gql `
|
|
24
|
+
query Message($id: LrRelayIdInput!) {
|
|
25
|
+
message(id: $id) {
|
|
26
|
+
id
|
|
27
|
+
sender {
|
|
28
|
+
username
|
|
29
|
+
}
|
|
30
|
+
receiver {
|
|
31
|
+
username
|
|
32
|
+
}
|
|
33
|
+
plainMessage
|
|
34
|
+
signedCipherMessage
|
|
35
|
+
sharedKey {
|
|
36
|
+
id
|
|
37
|
+
}
|
|
38
|
+
senderSigPbk {
|
|
39
|
+
id
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
keyGraph {
|
|
43
|
+
...KeyGraphFragment
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
${KeyGraphFragment}
|
|
47
|
+
`;
|
|
48
|
+
export class MessageService {
|
|
49
|
+
constructor(lrApollo, keyGraph, encryptionService, keyExchangeService) {
|
|
50
|
+
this.lrApollo = lrApollo;
|
|
51
|
+
this.keyGraph = keyGraph;
|
|
52
|
+
this.encryptionService = encryptionService;
|
|
53
|
+
this.keyExchangeService = keyExchangeService;
|
|
54
|
+
this.encrypt = this.encryptionService.encrypt.bind(this.encryptionService);
|
|
55
|
+
this.decrypt = this.encryptionService.decrypt.bind(this.encryptionService);
|
|
56
|
+
this.sign = this.encryptionService.sign.bind(this.encryptionService);
|
|
57
|
+
this.verify = this.encryptionService.verify.bind(this.encryptionService);
|
|
58
|
+
}
|
|
59
|
+
sendMessage({ username, userId, plainMessageJson, plainCipherMessageJson, }) {
|
|
60
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
61
|
+
const userSharedKey = yield this.keyExchangeService.currentUserSharedKey({
|
|
62
|
+
username,
|
|
63
|
+
userId,
|
|
64
|
+
});
|
|
65
|
+
const input = {
|
|
66
|
+
receiverUsername: username,
|
|
67
|
+
receiverId: userId,
|
|
68
|
+
sharedKeyId: userSharedKey.sharedKey.id,
|
|
69
|
+
senderSigPbkId: userSharedKey.userSigPrk.id,
|
|
70
|
+
};
|
|
71
|
+
if (plainCipherMessageJson) {
|
|
72
|
+
const sharedKey = yield this.keyGraph.getJwkKey(userSharedKey.sharedKey.id);
|
|
73
|
+
const cipherMessage = yield this.encrypt(sharedKey, plainCipherMessageJson);
|
|
74
|
+
const senderSigPrk = yield this.keyGraph.getJwkKey(userSharedKey.userSigPrk.id);
|
|
75
|
+
const signedCipherMessage = yield this.sign(senderSigPrk, cipherMessage);
|
|
76
|
+
input.signedCipherMessage = JSON.stringify(signedCipherMessage);
|
|
77
|
+
}
|
|
78
|
+
if (plainMessageJson) {
|
|
79
|
+
input.plainMessage = JSON.stringify(plainMessageJson);
|
|
80
|
+
}
|
|
81
|
+
const res = yield this.lrApollo.query({
|
|
82
|
+
query: SendMessageMutation,
|
|
83
|
+
variables: {
|
|
84
|
+
input,
|
|
85
|
+
},
|
|
86
|
+
});
|
|
87
|
+
return res.sendMessage;
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
decryptMessage(message, { sharedKey, senderSigPbk }) {
|
|
91
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
92
|
+
const signedCipherMessage = yield this.verify(senderSigPbk, JSON.parse(message.signedCipherMessage));
|
|
93
|
+
message.plainSignedCipherMessageJson = yield this.decrypt(sharedKey, signedCipherMessage);
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
getMessage(id) {
|
|
97
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
98
|
+
const res = yield this.lrApollo.query({
|
|
99
|
+
query: MessageQuery,
|
|
100
|
+
variables: {
|
|
101
|
+
id,
|
|
102
|
+
},
|
|
103
|
+
});
|
|
104
|
+
this.keyGraph.addKeys(res.keyGraph);
|
|
105
|
+
const message = res.message;
|
|
106
|
+
const sharedKey = yield this.keyGraph.getJwkKey(message.sharedKey.id);
|
|
107
|
+
// The sender would be getting the Prk back. The receiver gets the Pbk back.
|
|
108
|
+
// But only the Pbk is needed here to verify signature.
|
|
109
|
+
// So both sender and receiver can access this message.
|
|
110
|
+
const senderSigPbk = yield this.keyGraph.getJwkKey(message.senderSigPbk.id);
|
|
111
|
+
// Test bad signature
|
|
112
|
+
// senderSigPbk = senderSigPbk.toJSON();
|
|
113
|
+
// senderSigPbk.n = "x" + senderSigPbk.n.substring(1);
|
|
114
|
+
// senderSigPbk = await KFS.asKey(senderSigPbk);
|
|
115
|
+
yield this.decryptMessage(message, {
|
|
116
|
+
sharedKey,
|
|
117
|
+
senderSigPbk,
|
|
118
|
+
});
|
|
119
|
+
if (message.plainMessage) {
|
|
120
|
+
message.plainMessageJson = JSON.parse(message.plainMessage);
|
|
121
|
+
}
|
|
122
|
+
return res.message;
|
|
123
|
+
});
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
MessageService.ɵprov = i0.ɵɵdefineInjectable({ factory: function MessageService_Factory() { return new MessageService(i0.ɵɵinject(i1.LrApolloService), i0.ɵɵinject(i2.KeyGraphService), i0.ɵɵinject(i3.EncryptionService), i0.ɵɵinject(i4.KeyExchangeService)); }, token: MessageService, providedIn: "root" });
|
|
127
|
+
MessageService.decorators = [
|
|
128
|
+
{ type: Injectable, args: [{
|
|
129
|
+
providedIn: 'root',
|
|
130
|
+
},] }
|
|
131
|
+
];
|
|
132
|
+
MessageService.ctorParameters = () => [
|
|
133
|
+
{ type: LrApolloService },
|
|
134
|
+
{ type: KeyGraphService },
|
|
135
|
+
{ type: EncryptionService },
|
|
136
|
+
{ type: KeyExchangeService }
|
|
137
|
+
];
|
|
138
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"message.service.js","sourceRoot":"C:/Projects/newrepo/kc-client/projects/core/src/","sources":["lib/api/message.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport gql from 'graphql-tag';\r\nimport { JWK } from 'node-jose';\r\nimport { EncryptionService } from '../cryptography/encryption.service';\r\nimport { KeyGraphService } from '../cryptography/key-graph.service';\r\nimport { KeyGraphFragment } from '../_common/queries.gql';\r\nimport { KeyExchangeService } from './key-exchange.service';\r\nimport { LrApolloService } from './lr-apollo.service';\r\nimport { KeyFactoryService as KFS } from '../cryptography/key-factory.service';\r\n\r\nexport const SendMessageMutation = gql`\r\n  mutation SendMessage($input: SendMessageInput!) {\r\n    sendMessage(input: $input) {\r\n      message {\r\n        id\r\n      }\r\n    }\r\n  }\r\n`;\r\n\r\nexport const MessageQuery = gql`\r\n  query Message($id: LrRelayIdInput!) {\r\n    message(id: $id) {\r\n      id\r\n      sender {\r\n        username\r\n      }\r\n      receiver {\r\n        username\r\n      }\r\n      plainMessage\r\n      signedCipherMessage\r\n      sharedKey {\r\n        id\r\n      }\r\n      senderSigPbk {\r\n        id\r\n      }\r\n    }\r\n    keyGraph {\r\n      ...KeyGraphFragment\r\n    }\r\n  }\r\n  ${KeyGraphFragment}\r\n`;\r\n\r\nexport interface SendMessage {\r\n  message: {\r\n    id: string;\r\n  };\r\n}\r\n\r\nexport interface SendMessageInput {\r\n  username?: string;\r\n  userId?: string;\r\n  plainMessageJson?: any;\r\n  plainCipherMessageJson?: any;\r\n}\r\n\r\nexport interface Message {\r\n  id: string;\r\n  sender: {\r\n    id: string;\r\n    username: string;\r\n  };\r\n  receiver: {\r\n    id: string;\r\n    username: string;\r\n  };\r\n  plainMessage: string;\r\n  plainMessageJson?: any;\r\n  signedCipherMessage: string;\r\n  plainSignedCipherMessageJson?: any;\r\n  senderSigPbk: {\r\n    id: string;\r\n  };\r\n  sharedKey: {\r\n    id: string;\r\n  };\r\n}\r\n\r\ninterface DecryptMessageOptions {\r\n  sharedKey: JWK.Key;\r\n  senderSigPbk: JWK.Key;\r\n}\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class MessageService {\r\n  private readonly encrypt = this.encryptionService.encrypt.bind(\r\n    this.encryptionService\r\n  );\r\n  private readonly decrypt = this.encryptionService.decrypt.bind(\r\n    this.encryptionService\r\n  );\r\n  private readonly sign = this.encryptionService.sign.bind(\r\n    this.encryptionService\r\n  );\r\n  private readonly verify = this.encryptionService.verify.bind(\r\n    this.encryptionService\r\n  );\r\n\r\n  constructor(\r\n    private lrApollo: LrApolloService,\r\n    private keyGraph: KeyGraphService,\r\n    private encryptionService: EncryptionService,\r\n    private keyExchangeService: KeyExchangeService\r\n  ) {}\r\n\r\n  async sendMessage({\r\n    username,\r\n    userId,\r\n    plainMessageJson,\r\n    plainCipherMessageJson,\r\n  }: SendMessageInput): Promise<SendMessage> {\r\n    const userSharedKey = await this.keyExchangeService.currentUserSharedKey({\r\n      username,\r\n      userId,\r\n    });\r\n\r\n    const input: any = {\r\n      receiverUsername: username,\r\n      receiverId: userId,\r\n      sharedKeyId: userSharedKey.sharedKey.id,\r\n      senderSigPbkId: userSharedKey.userSigPrk.id,\r\n    };\r\n\r\n    if (plainCipherMessageJson) {\r\n      const sharedKey = await this.keyGraph.getJwkKey(\r\n        userSharedKey.sharedKey.id\r\n      );\r\n      const cipherMessage = await this.encrypt(\r\n        sharedKey,\r\n        plainCipherMessageJson\r\n      );\r\n\r\n      const senderSigPrk = await this.keyGraph.getJwkKey(\r\n        userSharedKey.userSigPrk.id\r\n      );\r\n      const signedCipherMessage = await this.sign(senderSigPrk, cipherMessage);\r\n\r\n      input.signedCipherMessage = JSON.stringify(signedCipherMessage);\r\n    }\r\n\r\n    if (plainMessageJson) {\r\n      input.plainMessage = JSON.stringify(plainMessageJson);\r\n    }\r\n\r\n    const res = await this.lrApollo.query<any>({\r\n      query: SendMessageMutation,\r\n      variables: {\r\n        input,\r\n      },\r\n    });\r\n\r\n    return res.sendMessage;\r\n  }\r\n\r\n  async decryptMessage(\r\n    message: Message,\r\n    { sharedKey, senderSigPbk }: DecryptMessageOptions\r\n  ): Promise<void> {\r\n    const signedCipherMessage = await this.verify(\r\n      senderSigPbk,\r\n      JSON.parse(message.signedCipherMessage)\r\n    );\r\n\r\n    message.plainSignedCipherMessageJson = await this.decrypt(\r\n      sharedKey,\r\n      signedCipherMessage\r\n    );\r\n  }\r\n\r\n  async getMessage(id: string): Promise<Message> {\r\n    const res = await this.lrApollo.query<any>({\r\n      query: MessageQuery,\r\n      variables: {\r\n        id,\r\n      },\r\n    });\r\n\r\n    this.keyGraph.addKeys(res.keyGraph);\r\n\r\n    const message = res.message as Message;\r\n\r\n    const sharedKey = await this.keyGraph.getJwkKey(message.sharedKey.id);\r\n\r\n    // The sender would be getting the Prk back. The receiver gets the Pbk back.\r\n    // But only the Pbk is needed here to verify signature.\r\n    // So both sender and receiver can access this message.\r\n    const senderSigPbk = await this.keyGraph.getJwkKey(message.senderSigPbk.id);\r\n\r\n    // Test bad signature\r\n    // senderSigPbk = senderSigPbk.toJSON();\r\n    // senderSigPbk.n = \"x\" + senderSigPbk.n.substring(1);\r\n    // senderSigPbk = await KFS.asKey(senderSigPbk);\r\n\r\n    await this.decryptMessage(message, {\r\n      sharedKey,\r\n      senderSigPbk,\r\n    });\r\n\r\n    if (message.plainMessage) {\r\n      message.plainMessageJson = JSON.parse(message.plainMessage);\r\n    }\r\n\r\n    return res.message;\r\n  }\r\n}\r\n"]}
|