@lifeready/core 1.0.21 → 1.0.22
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 +9745 -9700
- package/bundles/lifeready-core.umd.js.map +1 -1
- package/bundles/lifeready-core.umd.min.js +2 -2
- package/bundles/lifeready-core.umd.min.js.map +1 -1
- package/esm2015/lib/_common/run-outside-angular.js +2 -2
- package/esm2015/lib/_common/types.js +1 -1
- package/esm2015/lib/api/lr-apollo.service.js +3 -3
- package/esm2015/lib/api/lr-graphql/lr-graphql.service.js +3 -3
- package/esm2015/lib/api/query-processor/common-processors.service.js +3 -3
- package/esm2015/lib/api/query-processor/query-processor.service.js +4 -4
- package/esm2015/lib/api/query-processor/tp-password-reset-processor.service.js +6 -5
- package/esm2015/lib/api/types/lr-graphql.types.js +1 -1
- package/esm2015/lib/auth/auth.gql.js +1 -28
- package/esm2015/lib/auth/auth.types.js +1 -1
- package/esm2015/lib/auth/life-ready-auth.service.js +32 -31
- package/esm2015/lib/category/category.gql.js +1 -1
- package/esm2015/lib/category/category.service.js +6 -6
- package/esm2015/lib/contact-card/contact-card.gql.js +79 -0
- package/esm2015/lib/contact-card/contact-card.service.js +154 -0
- package/esm2015/lib/contact-card/contact-card2.gql.js +29 -0
- package/esm2015/lib/contact-card/contact-card2.service.js +103 -0
- package/esm2015/lib/encryption/encryption.service.js +189 -0
- package/esm2015/lib/file-upload/file-upload.service.js +74 -0
- package/esm2015/lib/file-upload/file-upload.types.js +1 -0
- package/esm2015/lib/{auth → idle}/idle.service.js +7 -7
- package/esm2015/lib/{auth → idle}/idle.types.js +1 -1
- package/esm2015/lib/items2/item2.service.js +20 -20
- package/esm2015/lib/key/key-factory.service.js +237 -0
- package/esm2015/lib/{cryptography → key}/key-graph.service.js +10 -10
- package/esm2015/lib/key/key-meta.service.js +200 -0
- package/esm2015/lib/key/key.service.js +124 -0
- package/esm2015/lib/key/key.types.js +11 -0
- package/esm2015/lib/key-exchange/key-exchange.gql.js +188 -0
- package/esm2015/lib/key-exchange/key-exchange.service.js +443 -0
- package/esm2015/lib/key-exchange/key-exchange.types.js +7 -0
- package/esm2015/lib/key-exchange/key-exchange2.gql.js +171 -0
- package/esm2015/lib/key-exchange/key-exchange2.service.js +500 -0
- package/esm2015/lib/lbop/lbop.service.js +355 -0
- package/esm2015/lib/life-ready.module.js +2 -27
- package/esm2015/lib/lock/lock.gql.js +40 -0
- package/esm2015/lib/lock/lock.service.js +64 -0
- package/esm2015/lib/message/message.gql.js +32 -0
- package/esm2015/lib/message/message.service.js +116 -0
- package/esm2015/lib/message/message.types.js +1 -0
- package/esm2015/lib/password/password.gql.js +28 -0
- package/esm2015/lib/password/password.service.js +315 -0
- package/esm2015/lib/persist/persist.service.js +180 -0
- package/esm2015/lib/profile/profile-details.service.js +214 -0
- package/esm2015/lib/profile/profile.gql.js +97 -0
- package/esm2015/lib/profile/profile.service.js +169 -0
- package/esm2015/lib/profile/profile.types.js +34 -0
- package/esm2015/lib/record/record-attachment.service.js +15 -15
- package/esm2015/lib/record/record.service.js +3 -3
- package/esm2015/lib/register/register.service.js +172 -0
- package/esm2015/lib/scenario/scenario.controller.js +2 -2
- package/esm2015/lib/scenario/{scenario.gql.private.js → scenario.private.gql.js} +1 -1
- package/esm2015/lib/scenario/scenario.service.js +9 -9
- package/esm2015/lib/scenario/scenario.types.js +1 -1
- package/esm2015/lib/shared-contact-card/shared-contact-card.service.js +119 -0
- package/esm2015/lib/shared-contact-card/shared-contact-card2.gql.js +41 -0
- package/esm2015/lib/shared-contact-card/shared-contact-card2.service.js +117 -0
- package/esm2015/lib/slip39/slip39.service.js +169 -0
- package/esm2015/lib/time/time.service.js +146 -0
- package/esm2015/lib/tp-assembly/tp-assembly.js +365 -0
- package/esm2015/lib/tp-assembly/tp-assembly.private.gql.js +22 -0
- package/esm2015/lib/tp-assembly/tp-assembly.types.js +1 -0
- package/esm2015/lib/tp-password-reset/tp-password-reset-request.service.js +100 -0
- package/esm2015/lib/tp-password-reset/tp-password-reset-user.service.js +117 -0
- package/esm2015/lib/tp-password-reset/tp-password-reset.constants.js +4 -0
- package/esm2015/lib/tp-password-reset/tp-password-reset.controller.js +34 -0
- package/esm2015/lib/tp-password-reset/tp-password-reset.gql.js +74 -0
- package/esm2015/lib/tp-password-reset/tp-password-reset.private.gql.js +165 -0
- package/esm2015/lib/tp-password-reset/tp-password-reset.private.service.js +54 -0
- package/esm2015/lib/tp-password-reset/tp-password-reset.service.js +92 -0
- package/esm2015/lib/tp-password-reset/tp-password-reset.types.js +1 -0
- package/esm2015/lib/trusted-party/trusted-party.gql.js +148 -0
- package/esm2015/lib/trusted-party/trusted-party.service.js +326 -0
- package/esm2015/lib/trusted-party/trusted-party.types.js +41 -0
- package/esm2015/lib/trusted-party/trusted-party2.gql.js +64 -0
- package/esm2015/lib/trusted-party/trusted-party2.gql.private.js +25 -0
- package/esm2015/lib/trusted-party/trusted-party2.service.js +224 -0
- package/esm2015/lib/trusted-party/trusted-party2.types.js +1 -0
- package/esm2015/lib/two-factor/two-factor.service.js +74 -0
- package/esm2015/lib/user/user.gql.js +60 -0
- package/esm2015/lib/user/user.service.js +79 -0
- package/esm2015/lib/user/user.types.js +1 -0
- package/esm2015/lib/web-crypto/web-crypto.service.js +29 -0
- package/esm2015/lifeready-core.js +15 -13
- package/esm2015/public-api.js +49 -51
- package/fesm2015/lifeready-core.js +9232 -9214
- package/fesm2015/lifeready-core.js.map +1 -1
- package/lib/_common/types.d.ts +3 -1
- package/lib/api/lr-apollo.service.d.ts +1 -1
- package/lib/api/lr-graphql/lr-graphql.service.d.ts +1 -1
- package/lib/api/query-processor/common-processors.service.d.ts +1 -1
- package/lib/api/query-processor/query-processor.service.d.ts +1 -1
- package/lib/api/query-processor/tp-password-reset-processor.service.d.ts +1 -1
- package/lib/api/types/lr-graphql.types.d.ts +11 -0
- package/lib/auth/auth.gql.d.ts +0 -3
- package/lib/auth/auth.types.d.ts +2 -2
- package/lib/auth/life-ready-auth.service.d.ts +12 -12
- package/lib/category/category.gql.d.ts +1 -1
- package/lib/category/category.service.d.ts +2 -2
- package/lib/{api → contact-card}/contact-card.service.d.ts +9 -9
- package/lib/contact-card/contact-card2.gql.d.ts +25 -0
- package/lib/{api → contact-card}/contact-card2.service.d.ts +11 -12
- package/lib/{cryptography → encryption}/encryption.service.d.ts +2 -2
- package/lib/{api/file.service.d.ts → file-upload/file-upload.service.d.ts} +3 -7
- package/lib/file-upload/file-upload.types.d.ts +5 -0
- package/lib/{auth → idle}/idle.service.d.ts +4 -4
- package/lib/items2/item2.service.d.ts +11 -11
- package/lib/{cryptography → key}/key-factory.service.d.ts +2 -2
- package/lib/{cryptography → key}/key-graph.service.d.ts +5 -5
- package/lib/{cryptography → key}/key-meta.service.d.ts +1 -1
- package/lib/{cryptography → key}/key.service.d.ts +2 -2
- package/lib/{cryptography/cryptography.types.d.ts → key/key.types.d.ts} +9 -13
- package/lib/{api → key-exchange}/key-exchange.service.d.ts +5 -5
- package/lib/{api → key-exchange}/key-exchange.types.d.ts +4 -4
- package/lib/{api → key-exchange}/key-exchange2.gql.d.ts +1 -1
- package/lib/{api → key-exchange}/key-exchange2.service.d.ts +71 -18
- package/lib/{auth → lbop}/lbop.service.d.ts +7 -7
- package/lib/{api → lock}/lock.gql.d.ts +1 -1
- package/lib/{api → lock}/lock.service.d.ts +1 -1
- package/lib/message/message.gql.d.ts +13 -0
- package/lib/message/message.service.d.ts +29 -0
- package/lib/message/message.types.d.ts +12 -0
- package/lib/password/password.gql.d.ts +3 -0
- package/lib/{auth → password}/password.service.d.ts +8 -8
- package/lib/{api → persist}/persist.service.d.ts +3 -3
- package/lib/{users → profile}/profile-details.service.d.ts +3 -3
- package/lib/{users → profile}/profile.gql.d.ts +2 -2
- package/lib/{users → profile}/profile.service.d.ts +6 -6
- package/lib/{users → profile}/profile.types.d.ts +1 -1
- package/lib/record/record-attachment.service.d.ts +6 -6
- package/lib/record/record.service.d.ts +1 -1
- package/lib/{auth → register}/register.service.d.ts +4 -4
- package/lib/scenario/scenario.controller.d.ts +1 -1
- package/lib/scenario/scenario.service.d.ts +2 -2
- package/lib/scenario/scenario.types.d.ts +1 -1
- package/lib/{api → shared-contact-card}/shared-contact-card.service.d.ts +9 -9
- package/lib/{api → shared-contact-card}/shared-contact-card2.gql.d.ts +1 -1
- package/lib/{api → shared-contact-card}/shared-contact-card2.service.d.ts +6 -6
- package/lib/{trusted-parties → tp-assembly}/tp-assembly.d.ts +7 -7
- package/lib/{trusted-parties → tp-assembly}/tp-assembly.types.d.ts +1 -1
- package/lib/{trusted-parties → tp-password-reset}/tp-password-reset-request.service.d.ts +4 -8
- package/lib/{trusted-parties → tp-password-reset}/tp-password-reset-user.service.d.ts +7 -13
- package/lib/{trusted-parties → tp-password-reset}/tp-password-reset.controller.d.ts +1 -1
- package/lib/tp-password-reset/tp-password-reset.gql.d.ts +63 -0
- package/lib/{trusted-parties/tp-password-reset.gql.d.ts → tp-password-reset/tp-password-reset.private.gql.d.ts} +1 -63
- package/lib/tp-password-reset/tp-password-reset.private.service.d.ts +59 -0
- package/lib/{trusted-parties → tp-password-reset}/tp-password-reset.service.d.ts +6 -89
- package/lib/tp-password-reset/tp-password-reset.types.d.ts +40 -0
- package/lib/{trusted-parties → trusted-party}/trusted-party.service.d.ts +7 -7
- package/lib/{trusted-parties → trusted-party}/trusted-party.types.d.ts +2 -3
- package/lib/{trusted-parties → trusted-party}/trusted-party2.gql.d.ts +0 -22
- package/lib/trusted-party/trusted-party2.gql.private.d.ts +23 -0
- package/lib/{trusted-parties → trusted-party}/trusted-party2.service.d.ts +11 -35
- package/lib/trusted-party/trusted-party2.types.d.ts +12 -0
- package/lib/{users → user}/user.gql.d.ts +1 -1
- package/lib/{users → user}/user.types.d.ts +1 -1
- package/lifeready-core.d.ts +14 -12
- package/lifeready-core.metadata.json +1 -1
- package/package.json +1 -1
- package/public-api.d.ts +48 -50
- package/esm2015/lib/api/contact-card.gql.js +0 -79
- package/esm2015/lib/api/contact-card.service.js +0 -154
- package/esm2015/lib/api/contact-card2.gql.js +0 -60
- package/esm2015/lib/api/contact-card2.service.js +0 -103
- package/esm2015/lib/api/file.service.js +0 -74
- package/esm2015/lib/api/key-exchange.gql.js +0 -188
- package/esm2015/lib/api/key-exchange.service.js +0 -442
- package/esm2015/lib/api/key-exchange.types.js +0 -7
- package/esm2015/lib/api/key-exchange2.gql.js +0 -171
- package/esm2015/lib/api/key-exchange2.service.js +0 -480
- package/esm2015/lib/api/lock.gql.js +0 -40
- package/esm2015/lib/api/lock.service.js +0 -64
- package/esm2015/lib/api/message.service.js +0 -138
- package/esm2015/lib/api/persist.service.js +0 -181
- package/esm2015/lib/api/shared-contact-card.service.js +0 -119
- package/esm2015/lib/api/shared-contact-card2.gql.js +0 -41
- package/esm2015/lib/api/shared-contact-card2.service.js +0 -117
- package/esm2015/lib/api/time.service.js +0 -146
- package/esm2015/lib/auth/lbop.service.js +0 -355
- package/esm2015/lib/auth/password.service.js +0 -315
- package/esm2015/lib/auth/register.service.js +0 -172
- package/esm2015/lib/auth/two-factor.service.js +0 -74
- package/esm2015/lib/cryptography/cryptography.types.js +0 -11
- package/esm2015/lib/cryptography/encryption.service.js +0 -189
- package/esm2015/lib/cryptography/key-factory.service.js +0 -237
- package/esm2015/lib/cryptography/key-meta.service.js +0 -200
- package/esm2015/lib/cryptography/key.service.js +0 -124
- package/esm2015/lib/cryptography/slip39.service.js +0 -169
- package/esm2015/lib/cryptography/web-crypto.service.js +0 -29
- package/esm2015/lib/trusted-parties/tp-assembly.gql.private.js +0 -22
- package/esm2015/lib/trusted-parties/tp-assembly.js +0 -365
- package/esm2015/lib/trusted-parties/tp-assembly.types.js +0 -1
- package/esm2015/lib/trusted-parties/tp-password-reset-request.service.js +0 -113
- package/esm2015/lib/trusted-parties/tp-password-reset-user.service.js +0 -129
- package/esm2015/lib/trusted-parties/tp-password-reset.constants.js +0 -4
- package/esm2015/lib/trusted-parties/tp-password-reset.controller.js +0 -34
- package/esm2015/lib/trusted-parties/tp-password-reset.gql.js +0 -237
- package/esm2015/lib/trusted-parties/tp-password-reset.service.js +0 -95
- package/esm2015/lib/trusted-parties/trusted-party.gql.js +0 -148
- package/esm2015/lib/trusted-parties/trusted-party.service.js +0 -326
- package/esm2015/lib/trusted-parties/trusted-party.types.js +0 -41
- package/esm2015/lib/trusted-parties/trusted-party2.gql.js +0 -87
- package/esm2015/lib/trusted-parties/trusted-party2.service.js +0 -218
- package/esm2015/lib/users/profile-details.service.js +0 -214
- package/esm2015/lib/users/profile.gql.js +0 -97
- package/esm2015/lib/users/profile.service.js +0 -169
- package/esm2015/lib/users/profile.types.js +0 -34
- package/esm2015/lib/users/user.gql.js +0 -60
- package/esm2015/lib/users/user.service.js +0 -79
- package/esm2015/lib/users/user.types.js +0 -1
- package/lib/api/contact-card2.gql.d.ts +0 -34
- package/lib/api/message.service.d.ts +0 -59
- /package/lib/{api → contact-card}/contact-card.gql.d.ts +0 -0
- /package/lib/{auth → idle}/idle.types.d.ts +0 -0
- /package/lib/{api → key-exchange}/key-exchange.gql.d.ts +0 -0
- /package/lib/scenario/{scenario.gql.private.d.ts → scenario.private.gql.d.ts} +0 -0
- /package/lib/{cryptography → slip39}/slip39.service.d.ts +0 -0
- /package/lib/{api → time}/time.service.d.ts +0 -0
- /package/lib/{trusted-parties/tp-assembly.gql.private.d.ts → tp-assembly/tp-assembly.private.gql.d.ts} +0 -0
- /package/lib/{trusted-parties → tp-password-reset}/tp-password-reset.constants.d.ts +0 -0
- /package/lib/{trusted-parties → trusted-party}/trusted-party.gql.d.ts +0 -0
- /package/lib/{auth → two-factor}/two-factor.service.d.ts +0 -0
- /package/lib/{users → user}/user.service.d.ts +0 -0
- /package/lib/{cryptography → web-crypto}/web-crypto.service.d.ts +0 -0
|
@@ -0,0 +1,180 @@
|
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
2
|
+
import { Injectable, Injector, isDevMode } from '@angular/core';
|
|
3
|
+
import { CookieService } from 'ngx-cookie-service';
|
|
4
|
+
import { EncryptionService } from '../encryption/encryption.service';
|
|
5
|
+
import { KeyFactoryService as KFS } from '../key/key-factory.service';
|
|
6
|
+
import { LrBadArgumentException } from '../_common/exceptions';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "../key/key-factory.service";
|
|
9
|
+
import * as i2 from "ngx-cookie-service";
|
|
10
|
+
import * as i3 from "../encryption/encryption.service";
|
|
11
|
+
export class PersistService {
|
|
12
|
+
constructor(keyFactory, cookieService, encryptionService, injector) {
|
|
13
|
+
this.keyFactory = keyFactory;
|
|
14
|
+
this.cookieService = cookieService;
|
|
15
|
+
this.encryptionService = encryptionService;
|
|
16
|
+
this.injector = injector;
|
|
17
|
+
this.KEY_PREFIX = 'lrSession-';
|
|
18
|
+
this.cookieSecure = true;
|
|
19
|
+
this.serverSessionEncryptionKey = null;
|
|
20
|
+
if (isDevMode()) {
|
|
21
|
+
this.setCookieSecure(false);
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
setServerSessionEncryptionKey(key) {
|
|
25
|
+
this.serverSessionEncryptionKey = key;
|
|
26
|
+
}
|
|
27
|
+
clearServerSessionEncryptionKey() {
|
|
28
|
+
this.serverSessionEncryptionKey = null;
|
|
29
|
+
}
|
|
30
|
+
// It's important that set and delete cookie use exactly the same set of parameters.
|
|
31
|
+
getCookieParams() {
|
|
32
|
+
return {
|
|
33
|
+
path: '/',
|
|
34
|
+
domain: null,
|
|
35
|
+
secure: this.cookieSecure,
|
|
36
|
+
sameSite: 'Lax',
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
clear() {
|
|
40
|
+
// Remove all cookies
|
|
41
|
+
Object.keys(this.cookieService.getAll()).forEach((key) => {
|
|
42
|
+
if (key.startsWith(this.KEY_PREFIX)) {
|
|
43
|
+
this.deletePrefixedName(key);
|
|
44
|
+
}
|
|
45
|
+
});
|
|
46
|
+
// Remove all persisted session variables
|
|
47
|
+
Object.keys(localStorage).forEach((key) => {
|
|
48
|
+
if (key.startsWith(this.KEY_PREFIX)) {
|
|
49
|
+
this.deletePrefixedName(key);
|
|
50
|
+
}
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
setCookieSecure(value) {
|
|
54
|
+
this.cookieSecure = value;
|
|
55
|
+
if (!value) {
|
|
56
|
+
if (isDevMode()) {
|
|
57
|
+
console.warn('The cookie secure flag in persistService has been set to false, set it to true in production mode');
|
|
58
|
+
}
|
|
59
|
+
else {
|
|
60
|
+
throw new LrBadArgumentException('Can not set PersistService cookie secure flag to false in production mode.');
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
prefixName(name) {
|
|
65
|
+
return this.KEY_PREFIX + name;
|
|
66
|
+
}
|
|
67
|
+
delete(name) {
|
|
68
|
+
this.deletePrefixedName(this.prefixName(name));
|
|
69
|
+
}
|
|
70
|
+
deletePrefixedName(prefixedName) {
|
|
71
|
+
const params = this.getCookieParams();
|
|
72
|
+
this.cookieService.delete(prefixedName, // name: string,
|
|
73
|
+
params.path, // path?: string,
|
|
74
|
+
params.domain, // domain ?: string,
|
|
75
|
+
params.secure, // secure ?: boolean,
|
|
76
|
+
params.sameSite // sameSite ?: 'Lax' | 'None' | 'Strict'): void;
|
|
77
|
+
);
|
|
78
|
+
localStorage.removeItem(prefixedName);
|
|
79
|
+
}
|
|
80
|
+
set({ name, value, serverSession, expiry, }) {
|
|
81
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
82
|
+
const prefixedName = this.prefixName(name);
|
|
83
|
+
let item;
|
|
84
|
+
if (serverSession) {
|
|
85
|
+
item = {
|
|
86
|
+
serverSession: true,
|
|
87
|
+
data: yield this.encryptionService.encryptToString(this.serverSessionEncryptionKey, value),
|
|
88
|
+
};
|
|
89
|
+
}
|
|
90
|
+
else {
|
|
91
|
+
item = {
|
|
92
|
+
data: value,
|
|
93
|
+
};
|
|
94
|
+
}
|
|
95
|
+
if (expiry) {
|
|
96
|
+
const key = yield this.keyFactory.createKey();
|
|
97
|
+
item.expiry = expiry.toISOString();
|
|
98
|
+
item.data = yield this.encryptionService.encryptToString(key, item.data);
|
|
99
|
+
const cookieItem = {
|
|
100
|
+
key: key.toJSON(true),
|
|
101
|
+
};
|
|
102
|
+
// If path is set to anything other than "/" then the cookie is only
|
|
103
|
+
// accessible by JS if the current URL has the same prefix as the path.
|
|
104
|
+
// Ideally we don't want the encryption key cookie to be sent at all, but
|
|
105
|
+
// since the encrypted content is held in localstorage, it is not a security
|
|
106
|
+
// risk, i.e. it is at least as secure as storing only in localstorage.
|
|
107
|
+
const params = this.getCookieParams();
|
|
108
|
+
this.cookieService.set(prefixedName, // name: string,
|
|
109
|
+
JSON.stringify(cookieItem), // value: string,
|
|
110
|
+
expiry, // expires?: number | Date,
|
|
111
|
+
params.path, // path?: string,
|
|
112
|
+
params.domain, // domain?: string,
|
|
113
|
+
params.secure, // secure?: boolean,
|
|
114
|
+
params.sameSite // sameSite?: 'Lax' | 'None' | 'Strict'
|
|
115
|
+
);
|
|
116
|
+
}
|
|
117
|
+
localStorage.setItem(prefixedName, JSON.stringify(item));
|
|
118
|
+
});
|
|
119
|
+
}
|
|
120
|
+
get(name) {
|
|
121
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
122
|
+
const prefixedName = this.prefixName(name);
|
|
123
|
+
try {
|
|
124
|
+
const ret = yield this.getImpl(prefixedName);
|
|
125
|
+
if (ret == null) {
|
|
126
|
+
// Clear any cookies to keep things in sync.
|
|
127
|
+
this.deletePrefixedName(prefixedName);
|
|
128
|
+
}
|
|
129
|
+
return ret;
|
|
130
|
+
}
|
|
131
|
+
catch (error) {
|
|
132
|
+
this.deletePrefixedName(prefixedName);
|
|
133
|
+
throw error;
|
|
134
|
+
}
|
|
135
|
+
});
|
|
136
|
+
}
|
|
137
|
+
getImpl(name) {
|
|
138
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
139
|
+
const itemString = localStorage.getItem(name);
|
|
140
|
+
if (!itemString) {
|
|
141
|
+
return null;
|
|
142
|
+
}
|
|
143
|
+
const item = JSON.parse(itemString);
|
|
144
|
+
let data;
|
|
145
|
+
if (item.expiry) {
|
|
146
|
+
const cookieItemString = this.cookieService.get(name);
|
|
147
|
+
if (!cookieItemString) {
|
|
148
|
+
// Probably expired, but we won't make any interpretations since if we only used
|
|
149
|
+
// cookies we can't tell if it's expired or explicitly removed. So we just make
|
|
150
|
+
// the behaviour here consistent with that.
|
|
151
|
+
console.log('No cookie.');
|
|
152
|
+
return null;
|
|
153
|
+
}
|
|
154
|
+
const cookieItem = JSON.parse(cookieItemString);
|
|
155
|
+
const key = yield KFS.asKey(cookieItem.key);
|
|
156
|
+
data = yield this.encryptionService.decrypt(key, item.data);
|
|
157
|
+
}
|
|
158
|
+
else {
|
|
159
|
+
data = item.data;
|
|
160
|
+
}
|
|
161
|
+
if (item.serverSession) {
|
|
162
|
+
data = yield this.encryptionService.decrypt(this.serverSessionEncryptionKey, data);
|
|
163
|
+
}
|
|
164
|
+
return data;
|
|
165
|
+
});
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
PersistService.ɵprov = i0.ɵɵdefineInjectable({ factory: function PersistService_Factory() { return new PersistService(i0.ɵɵinject(i1.KeyFactoryService), i0.ɵɵinject(i2.CookieService), i0.ɵɵinject(i3.EncryptionService), i0.ɵɵinject(i0.INJECTOR)); }, token: PersistService, providedIn: "root" });
|
|
169
|
+
PersistService.decorators = [
|
|
170
|
+
{ type: Injectable, args: [{
|
|
171
|
+
providedIn: 'root',
|
|
172
|
+
},] }
|
|
173
|
+
];
|
|
174
|
+
PersistService.ctorParameters = () => [
|
|
175
|
+
{ type: KFS },
|
|
176
|
+
{ type: CookieService },
|
|
177
|
+
{ type: EncryptionService },
|
|
178
|
+
{ type: Injector }
|
|
179
|
+
];
|
|
180
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGVyc2lzdC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6Ii9vcHQvYXRsYXNzaWFuL3BpcGVsaW5lcy9hZ2VudC9idWlsZC9wcm9qZWN0cy9jb3JlL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9wZXJzaXN0L3BlcnNpc3Quc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxRQUFRLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2hFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUVuRCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUNyRSxPQUFPLEVBQUUsaUJBQWlCLElBQUksR0FBRyxFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDdEUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7Ozs7O0FBZS9ELE1BQU0sT0FBTyxjQUFjO0lBTXpCLFlBQ1UsVUFBZSxFQUNmLGFBQTRCLEVBQzVCLGlCQUFvQyxFQUNwQyxRQUFrQjtRQUhsQixlQUFVLEdBQVYsVUFBVSxDQUFLO1FBQ2Ysa0JBQWEsR0FBYixhQUFhLENBQWU7UUFDNUIsc0JBQWlCLEdBQWpCLGlCQUFpQixDQUFtQjtRQUNwQyxhQUFRLEdBQVIsUUFBUSxDQUFVO1FBVFgsZUFBVSxHQUFHLFlBQVksQ0FBQztRQUVuQyxpQkFBWSxHQUFHLElBQUksQ0FBQztRQUNwQiwrQkFBMEIsR0FBWSxJQUFJLENBQUM7UUFRakQsSUFBSSxTQUFTLEVBQUUsRUFBRTtZQUNmLElBQUksQ0FBQyxlQUFlLENBQUMsS0FBSyxDQUFDLENBQUM7U0FDN0I7SUFDSCxDQUFDO0lBRUQsNkJBQTZCLENBQUMsR0FBWTtRQUN4QyxJQUFJLENBQUMsMEJBQTBCLEdBQUcsR0FBRyxDQUFDO0lBQ3hDLENBQUM7SUFFRCwrQkFBK0I7UUFDN0IsSUFBSSxDQUFDLDBCQUEwQixHQUFHLElBQUksQ0FBQztJQUN6QyxDQUFDO0lBRUQsb0ZBQW9GO0lBQzVFLGVBQWU7UUFDckIsT0FBTztZQUNMLElBQUksRUFBRSxHQUFHO1lBQ1QsTUFBTSxFQUFFLElBQUk7WUFDWixNQUFNLEVBQUUsSUFBSSxDQUFDLFlBQVk7WUFDekIsUUFBUSxFQUFFLEtBQWtDO1NBQzdDLENBQUM7SUFDSixDQUFDO0lBRU0sS0FBSztRQUNWLHFCQUFxQjtRQUNyQixNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRTtZQUN2RCxJQUFJLEdBQUcsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxFQUFFO2dCQUNuQyxJQUFJLENBQUMsa0JBQWtCLENBQUMsR0FBRyxDQUFDLENBQUM7YUFDOUI7UUFDSCxDQUFDLENBQUMsQ0FBQztRQUVILHlDQUF5QztRQUN6QyxNQUFNLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFO1lBQ3hDLElBQUksR0FBRyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLEVBQUU7Z0JBQ25DLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxHQUFHLENBQUMsQ0FBQzthQUM5QjtRQUNILENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVNLGVBQWUsQ0FBQyxLQUFjO1FBQ25DLElBQUksQ0FBQyxZQUFZLEdBQUcsS0FBSyxDQUFDO1FBQzFCLElBQUksQ0FBQyxLQUFLLEVBQUU7WUFDVixJQUFJLFNBQVMsRUFBRSxFQUFFO2dCQUNmLE9BQU8sQ0FBQyxJQUFJLENBQ1YsbUdBQW1HLENBQ3BHLENBQUM7YUFDSDtpQkFBTTtnQkFDTCxNQUFNLElBQUksc0JBQXNCLENBQzlCLDRFQUE0RSxDQUM3RSxDQUFDO2FBQ0g7U0FDRjtJQUNILENBQUM7SUFFTyxVQUFVLENBQUMsSUFBWTtRQUM3QixPQUFPLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDO0lBQ2hDLENBQUM7SUFFTSxNQUFNLENBQUMsSUFBWTtRQUN4QixJQUFJLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO0lBQ2pELENBQUM7SUFFTyxrQkFBa0IsQ0FBQyxZQUFvQjtRQUM3QyxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsZUFBZSxFQUFFLENBQUM7UUFDdEMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQ3ZCLFlBQVksRUFBRSxnQkFBZ0I7UUFDOUIsTUFBTSxDQUFDLElBQUksRUFBRSxpQkFBaUI7UUFDOUIsTUFBTSxDQUFDLE1BQU0sRUFBRSxvQkFBb0I7UUFDbkMsTUFBTSxDQUFDLE1BQU0sRUFBRSxxQkFBcUI7UUFDcEMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxnREFBZ0Q7U0FDakUsQ0FBQztRQUNGLFlBQVksQ0FBQyxVQUFVLENBQUMsWUFBWSxDQUFDLENBQUM7SUFDeEMsQ0FBQztJQUVZLEdBQUcsQ0FBQyxFQUNmLElBQUksRUFDSixLQUFLLEVBQ0wsYUFBYSxFQUNiLE1BQU0sR0FNUDs7WUFDQyxNQUFNLFlBQVksR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxDQUFDO1lBRTNDLElBQUksSUFBVSxDQUFDO1lBRWYsSUFBSSxhQUFhLEVBQUU7Z0JBQ2pCLElBQUksR0FBRztvQkFDTCxhQUFhLEVBQUUsSUFBSTtvQkFDbkIsSUFBSSxFQUFFLE1BQU0sSUFBSSxDQUFDLGlCQUFpQixDQUFDLGVBQWUsQ0FDaEQsSUFBSSxDQUFDLDBCQUEwQixFQUMvQixLQUFLLENBQ047aUJBQ0YsQ0FBQzthQUNIO2lCQUFNO2dCQUNMLElBQUksR0FBRztvQkFDTCxJQUFJLEVBQUUsS0FBSztpQkFDWixDQUFDO2FBQ0g7WUFFRCxJQUFJLE1BQU0sRUFBRTtnQkFDVixNQUFNLEdBQUcsR0FBRyxNQUFNLElBQUksQ0FBQyxVQUFVLENBQUMsU0FBUyxFQUFFLENBQUM7Z0JBQzlDLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDLFdBQVcsRUFBRSxDQUFDO2dCQUNuQyxJQUFJLENBQUMsSUFBSSxHQUFHLE1BQU0sSUFBSSxDQUFDLGlCQUFpQixDQUFDLGVBQWUsQ0FBQyxHQUFHLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO2dCQUV6RSxNQUFNLFVBQVUsR0FBZTtvQkFDN0IsR0FBRyxFQUFFLEdBQUcsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDO2lCQUN0QixDQUFDO2dCQUVGLG9FQUFvRTtnQkFDcEUsdUVBQXVFO2dCQUN2RSx5RUFBeUU7Z0JBQ3pFLDRFQUE0RTtnQkFDNUUsdUVBQXVFO2dCQUN2RSxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsZUFBZSxFQUFFLENBQUM7Z0JBQ3RDLElBQUksQ0FBQyxhQUFhLENBQUMsR0FBRyxDQUNwQixZQUFZLEVBQUUsZ0JBQWdCO2dCQUM5QixJQUFJLENBQUMsU0FBUyxDQUFDLFVBQVUsQ0FBQyxFQUFFLGlCQUFpQjtnQkFDN0MsTUFBTSxFQUFFLDJCQUEyQjtnQkFDbkMsTUFBTSxDQUFDLElBQUksRUFBRSxpQkFBaUI7Z0JBQzlCLE1BQU0sQ0FBQyxNQUFNLEVBQUUsbUJBQW1CO2dCQUNsQyxNQUFNLENBQUMsTUFBTSxFQUFFLG9CQUFvQjtnQkFDbkMsTUFBTSxDQUFDLFFBQVEsQ0FBQyx1Q0FBdUM7aUJBQ3hELENBQUM7YUFDSDtZQUVELFlBQVksQ0FBQyxPQUFPLENBQUMsWUFBWSxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztRQUMzRCxDQUFDO0tBQUE7SUFFWSxHQUFHLENBQUMsSUFBWTs7WUFDM0IsTUFBTSxZQUFZLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUUzQyxJQUFJO2dCQUNGLE1BQU0sR0FBRyxHQUFHLE1BQU0sSUFBSSxDQUFDLE9BQU8sQ0FBQyxZQUFZLENBQUMsQ0FBQztnQkFDN0MsSUFBSSxHQUFHLElBQUksSUFBSSxFQUFFO29CQUNmLDRDQUE0QztvQkFDNUMsSUFBSSxDQUFDLGtCQUFrQixDQUFDLFlBQVksQ0FBQyxDQUFDO2lCQUN2QztnQkFDRCxPQUFPLEdBQUcsQ0FBQzthQUNaO1lBQUMsT0FBTyxLQUFLLEVBQUU7Z0JBQ2QsSUFBSSxDQUFDLGtCQUFrQixDQUFDLFlBQVksQ0FBQyxDQUFDO2dCQUN0QyxNQUFNLEtBQUssQ0FBQzthQUNiO1FBQ0gsQ0FBQztLQUFBO0lBRWEsT0FBTyxDQUFDLElBQVk7O1lBQ2hDLE1BQU0sVUFBVSxHQUFHLFlBQVksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDOUMsSUFBSSxDQUFDLFVBQVUsRUFBRTtnQkFDZixPQUFPLElBQUksQ0FBQzthQUNiO1lBRUQsTUFBTSxJQUFJLEdBQVMsSUFBSSxDQUFDLEtBQUssQ0FBQyxVQUFVLENBQUMsQ0FBQztZQUUxQyxJQUFJLElBQVMsQ0FBQztZQUVkLElBQUksSUFBSSxDQUFDLE1BQU0sRUFBRTtnQkFDZixNQUFNLGdCQUFnQixHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO2dCQUN0RCxJQUFJLENBQUMsZ0JBQWdCLEVBQUU7b0JBQ3JCLGdGQUFnRjtvQkFDaEYsK0VBQStFO29CQUMvRSwyQ0FBMkM7b0JBQzNDLE9BQU8sQ0FBQyxHQUFHLENBQUMsWUFBWSxDQUFDLENBQUM7b0JBQzFCLE9BQU8sSUFBSSxDQUFDO2lCQUNiO2dCQUVELE1BQU0sVUFBVSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztnQkFFaEQsTUFBTSxHQUFHLEdBQUcsTUFBTSxHQUFHLENBQUMsS0FBSyxDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQUMsQ0FBQztnQkFFNUMsSUFBSSxHQUFHLE1BQU0sSUFBSSxDQUFDLGlCQUFpQixDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO2FBQzdEO2lCQUFNO2dCQUNMLElBQUksR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDO2FBQ2xCO1lBRUQsSUFBSSxJQUFJLENBQUMsYUFBYSxFQUFFO2dCQUN0QixJQUFJLEdBQUcsTUFBTSxJQUFJLENBQUMsaUJBQWlCLENBQUMsT0FBTyxDQUN6QyxJQUFJLENBQUMsMEJBQTBCLEVBQy9CLElBQUksQ0FDTCxDQUFDO2FBQ0g7WUFFRCxPQUFPLElBQUksQ0FBQztRQUNkLENBQUM7S0FBQTs7OztZQXhNRixVQUFVLFNBQUM7Z0JBQ1YsVUFBVSxFQUFFLE1BQU07YUFDbkI7OztZQWY2QixHQUFHO1lBSHhCLGFBQWE7WUFFYixpQkFBaUI7WUFITCxRQUFRIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSwgSW5qZWN0b3IsIGlzRGV2TW9kZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29va2llU2VydmljZSB9IGZyb20gJ25neC1jb29raWUtc2VydmljZSc7XG5pbXBvcnQgeyBKV0sgfSBmcm9tICdub2RlLWpvc2UnO1xuaW1wb3J0IHsgRW5jcnlwdGlvblNlcnZpY2UgfSBmcm9tICcuLi9lbmNyeXB0aW9uL2VuY3J5cHRpb24uc2VydmljZSc7XG5pbXBvcnQgeyBLZXlGYWN0b3J5U2VydmljZSBhcyBLRlMgfSBmcm9tICcuLi9rZXkva2V5LWZhY3Rvcnkuc2VydmljZSc7XG5pbXBvcnQgeyBMckJhZEFyZ3VtZW50RXhjZXB0aW9uIH0gZnJvbSAnLi4vX2NvbW1vbi9leGNlcHRpb25zJztcblxuaW50ZXJmYWNlIEl0ZW0ge1xuICBkYXRhOiBzdHJpbmc7XG4gIGV4cGlyeT86IHN0cmluZzsgLy8gaXNvIGZvcm1hdFxuICBzZXJ2ZXJTZXNzaW9uPzogYm9vbGVhbjtcbn1cblxuaW50ZXJmYWNlIENvb2tpZUl0ZW0ge1xuICBrZXk6IGFueTtcbn1cblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCcsXG59KVxuZXhwb3J0IGNsYXNzIFBlcnNpc3RTZXJ2aWNlIHtcbiAgcHJpdmF0ZSByZWFkb25seSBLRVlfUFJFRklYID0gJ2xyU2Vzc2lvbi0nO1xuXG4gIHByaXZhdGUgY29va2llU2VjdXJlID0gdHJ1ZTtcbiAgcHJpdmF0ZSBzZXJ2ZXJTZXNzaW9uRW5jcnlwdGlvbktleTogSldLLktleSA9IG51bGw7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSBrZXlGYWN0b3J5OiBLRlMsXG4gICAgcHJpdmF0ZSBjb29raWVTZXJ2aWNlOiBDb29raWVTZXJ2aWNlLFxuICAgIHByaXZhdGUgZW5jcnlwdGlvblNlcnZpY2U6IEVuY3J5cHRpb25TZXJ2aWNlLFxuICAgIHByaXZhdGUgaW5qZWN0b3I6IEluamVjdG9yXG4gICkge1xuICAgIGlmIChpc0Rldk1vZGUoKSkge1xuICAgICAgdGhpcy5zZXRDb29raWVTZWN1cmUoZmFsc2UpO1xuICAgIH1cbiAgfVxuXG4gIHNldFNlcnZlclNlc3Npb25FbmNyeXB0aW9uS2V5KGtleTogSldLLktleSkge1xuICAgIHRoaXMuc2VydmVyU2Vzc2lvbkVuY3J5cHRpb25LZXkgPSBrZXk7XG4gIH1cblxuICBjbGVhclNlcnZlclNlc3Npb25FbmNyeXB0aW9uS2V5KCkge1xuICAgIHRoaXMuc2VydmVyU2Vzc2lvbkVuY3J5cHRpb25LZXkgPSBudWxsO1xuICB9XG5cbiAgLy8gSXQncyBpbXBvcnRhbnQgdGhhdCBzZXQgYW5kIGRlbGV0ZSBjb29raWUgdXNlIGV4YWN0bHkgdGhlIHNhbWUgc2V0IG9mIHBhcmFtZXRlcnMuXG4gIHByaXZhdGUgZ2V0Q29va2llUGFyYW1zKCkge1xuICAgIHJldHVybiB7XG4gICAgICBwYXRoOiAnLycsXG4gICAgICBkb21haW46IG51bGwsIC8vIHdoaWNoIG1lYW5zIHRoZSBjdXJyZW50IGRvbWFpbiBvZiB0aGUgZnJvbnRlbmQgYXBwLlxuICAgICAgc2VjdXJlOiB0aGlzLmNvb2tpZVNlY3VyZSxcbiAgICAgIHNhbWVTaXRlOiAnTGF4JyBhcyAnTGF4JyB8ICdOb25lJyB8ICdTdHJpY3QnLFxuICAgIH07XG4gIH1cblxuICBwdWJsaWMgY2xlYXIoKSB7XG4gICAgLy8gUmVtb3ZlIGFsbCBjb29raWVzXG4gICAgT2JqZWN0LmtleXModGhpcy5jb29raWVTZXJ2aWNlLmdldEFsbCgpKS5mb3JFYWNoKChrZXkpID0+IHtcbiAgICAgIGlmIChrZXkuc3RhcnRzV2l0aCh0aGlzLktFWV9QUkVGSVgpKSB7XG4gICAgICAgIHRoaXMuZGVsZXRlUHJlZml4ZWROYW1lKGtleSk7XG4gICAgICB9XG4gICAgfSk7XG5cbiAgICAvLyBSZW1vdmUgYWxsIHBlcnNpc3RlZCBzZXNzaW9uIHZhcmlhYmxlc1xuICAgIE9iamVjdC5rZXlzKGxvY2FsU3RvcmFnZSkuZm9yRWFjaCgoa2V5KSA9PiB7XG4gICAgICBpZiAoa2V5LnN0YXJ0c1dpdGgodGhpcy5LRVlfUFJFRklYKSkge1xuICAgICAgICB0aGlzLmRlbGV0ZVByZWZpeGVkTmFtZShrZXkpO1xuICAgICAgfVxuICAgIH0pO1xuICB9XG5cbiAgcHVibGljIHNldENvb2tpZVNlY3VyZSh2YWx1ZTogYm9vbGVhbikge1xuICAgIHRoaXMuY29va2llU2VjdXJlID0gdmFsdWU7XG4gICAgaWYgKCF2YWx1ZSkge1xuICAgICAgaWYgKGlzRGV2TW9kZSgpKSB7XG4gICAgICAgIGNvbnNvbGUud2FybihcbiAgICAgICAgICAnVGhlIGNvb2tpZSBzZWN1cmUgZmxhZyBpbiBwZXJzaXN0U2VydmljZSBoYXMgYmVlbiBzZXQgdG8gZmFsc2UsIHNldCBpdCB0byB0cnVlIGluIHByb2R1Y3Rpb24gbW9kZSdcbiAgICAgICAgKTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHRocm93IG5ldyBMckJhZEFyZ3VtZW50RXhjZXB0aW9uKFxuICAgICAgICAgICdDYW4gbm90IHNldCBQZXJzaXN0U2VydmljZSBjb29raWUgc2VjdXJlIGZsYWcgdG8gZmFsc2UgaW4gcHJvZHVjdGlvbiBtb2RlLidcbiAgICAgICAgKTtcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICBwcml2YXRlIHByZWZpeE5hbWUobmFtZTogc3RyaW5nKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy5LRVlfUFJFRklYICsgbmFtZTtcbiAgfVxuXG4gIHB1YmxpYyBkZWxldGUobmFtZTogc3RyaW5nKTogdm9pZCB7XG4gICAgdGhpcy5kZWxldGVQcmVmaXhlZE5hbWUodGhpcy5wcmVmaXhOYW1lKG5hbWUpKTtcbiAgfVxuXG4gIHByaXZhdGUgZGVsZXRlUHJlZml4ZWROYW1lKHByZWZpeGVkTmFtZTogc3RyaW5nKTogdm9pZCB7XG4gICAgY29uc3QgcGFyYW1zID0gdGhpcy5nZXRDb29raWVQYXJhbXMoKTtcbiAgICB0aGlzLmNvb2tpZVNlcnZpY2UuZGVsZXRlKFxuICAgICAgcHJlZml4ZWROYW1lLCAvLyBuYW1lOiBzdHJpbmcsXG4gICAgICBwYXJhbXMucGF0aCwgLy8gcGF0aD86IHN0cmluZyxcbiAgICAgIHBhcmFtcy5kb21haW4sIC8vIGRvbWFpbiA/OiBzdHJpbmcsXG4gICAgICBwYXJhbXMuc2VjdXJlLCAvLyBzZWN1cmUgPzogYm9vbGVhbixcbiAgICAgIHBhcmFtcy5zYW1lU2l0ZSAvLyBzYW1lU2l0ZSA/OiAnTGF4JyB8ICdOb25lJyB8ICdTdHJpY3QnKTogdm9pZDtcbiAgICApO1xuICAgIGxvY2FsU3RvcmFnZS5yZW1vdmVJdGVtKHByZWZpeGVkTmFtZSk7XG4gIH1cblxuICBwdWJsaWMgYXN5bmMgc2V0KHtcbiAgICBuYW1lLFxuICAgIHZhbHVlLFxuICAgIHNlcnZlclNlc3Npb24sXG4gICAgZXhwaXJ5LFxuICB9OiB7XG4gICAgbmFtZTogc3RyaW5nO1xuICAgIHZhbHVlOiBhbnk7XG4gICAgc2VydmVyU2Vzc2lvbjogYm9vbGVhbjtcbiAgICBleHBpcnk/OiBEYXRlO1xuICB9KTogUHJvbWlzZTx2b2lkPiB7XG4gICAgY29uc3QgcHJlZml4ZWROYW1lID0gdGhpcy5wcmVmaXhOYW1lKG5hbWUpO1xuXG4gICAgbGV0IGl0ZW06IEl0ZW07XG5cbiAgICBpZiAoc2VydmVyU2Vzc2lvbikge1xuICAgICAgaXRlbSA9IHtcbiAgICAgICAgc2VydmVyU2Vzc2lvbjogdHJ1ZSxcbiAgICAgICAgZGF0YTogYXdhaXQgdGhpcy5lbmNyeXB0aW9uU2VydmljZS5lbmNyeXB0VG9TdHJpbmcoXG4gICAgICAgICAgdGhpcy5zZXJ2ZXJTZXNzaW9uRW5jcnlwdGlvbktleSxcbiAgICAgICAgICB2YWx1ZVxuICAgICAgICApLFxuICAgICAgfTtcbiAgICB9IGVsc2Uge1xuICAgICAgaXRlbSA9IHtcbiAgICAgICAgZGF0YTogdmFsdWUsXG4gICAgICB9O1xuICAgIH1cblxuICAgIGlmIChleHBpcnkpIHtcbiAgICAgIGNvbnN0IGtleSA9IGF3YWl0IHRoaXMua2V5RmFjdG9yeS5jcmVhdGVLZXkoKTtcbiAgICAgIGl0ZW0uZXhwaXJ5ID0gZXhwaXJ5LnRvSVNPU3RyaW5nKCk7XG4gICAgICBpdGVtLmRhdGEgPSBhd2FpdCB0aGlzLmVuY3J5cHRpb25TZXJ2aWNlLmVuY3J5cHRUb1N0cmluZyhrZXksIGl0ZW0uZGF0YSk7XG5cbiAgICAgIGNvbnN0IGNvb2tpZUl0ZW06IENvb2tpZUl0ZW0gPSB7XG4gICAgICAgIGtleToga2V5LnRvSlNPTih0cnVlKSxcbiAgICAgIH07XG5cbiAgICAgIC8vIElmIHBhdGggaXMgc2V0IHRvIGFueXRoaW5nIG90aGVyIHRoYW4gXCIvXCIgdGhlbiB0aGUgY29va2llIGlzIG9ubHlcbiAgICAgIC8vIGFjY2Vzc2libGUgYnkgSlMgaWYgdGhlIGN1cnJlbnQgVVJMIGhhcyB0aGUgc2FtZSBwcmVmaXggYXMgdGhlIHBhdGguXG4gICAgICAvLyBJZGVhbGx5IHdlIGRvbid0IHdhbnQgdGhlIGVuY3J5cHRpb24ga2V5IGNvb2tpZSB0byBiZSBzZW50IGF0IGFsbCwgYnV0XG4gICAgICAvLyBzaW5jZSB0aGUgZW5jcnlwdGVkIGNvbnRlbnQgaXMgaGVsZCBpbiBsb2NhbHN0b3JhZ2UsIGl0IGlzIG5vdCBhIHNlY3VyaXR5XG4gICAgICAvLyByaXNrLCBpLmUuIGl0IGlzIGF0IGxlYXN0IGFzIHNlY3VyZSBhcyBzdG9yaW5nIG9ubHkgaW4gbG9jYWxzdG9yYWdlLlxuICAgICAgY29uc3QgcGFyYW1zID0gdGhpcy5nZXRDb29raWVQYXJhbXMoKTtcbiAgICAgIHRoaXMuY29va2llU2VydmljZS5zZXQoXG4gICAgICAgIHByZWZpeGVkTmFtZSwgLy8gbmFtZTogc3RyaW5nLFxuICAgICAgICBKU09OLnN0cmluZ2lmeShjb29raWVJdGVtKSwgLy8gdmFsdWU6IHN0cmluZyxcbiAgICAgICAgZXhwaXJ5LCAvLyBleHBpcmVzPzogbnVtYmVyIHwgRGF0ZSxcbiAgICAgICAgcGFyYW1zLnBhdGgsIC8vIHBhdGg/OiBzdHJpbmcsXG4gICAgICAgIHBhcmFtcy5kb21haW4sIC8vIGRvbWFpbj86IHN0cmluZyxcbiAgICAgICAgcGFyYW1zLnNlY3VyZSwgLy8gc2VjdXJlPzogYm9vbGVhbixcbiAgICAgICAgcGFyYW1zLnNhbWVTaXRlIC8vIHNhbWVTaXRlPzogJ0xheCcgfCAnTm9uZScgfCAnU3RyaWN0J1xuICAgICAgKTtcbiAgICB9XG5cbiAgICBsb2NhbFN0b3JhZ2Uuc2V0SXRlbShwcmVmaXhlZE5hbWUsIEpTT04uc3RyaW5naWZ5KGl0ZW0pKTtcbiAgfVxuXG4gIHB1YmxpYyBhc3luYyBnZXQobmFtZTogc3RyaW5nKTogUHJvbWlzZTxhbnk+IHtcbiAgICBjb25zdCBwcmVmaXhlZE5hbWUgPSB0aGlzLnByZWZpeE5hbWUobmFtZSk7XG5cbiAgICB0cnkge1xuICAgICAgY29uc3QgcmV0ID0gYXdhaXQgdGhpcy5nZXRJbXBsKHByZWZpeGVkTmFtZSk7XG4gICAgICBpZiAocmV0ID09IG51bGwpIHtcbiAgICAgICAgLy8gQ2xlYXIgYW55IGNvb2tpZXMgdG8ga2VlcCB0aGluZ3MgaW4gc3luYy5cbiAgICAgICAgdGhpcy5kZWxldGVQcmVmaXhlZE5hbWUocHJlZml4ZWROYW1lKTtcbiAgICAgIH1cbiAgICAgIHJldHVybiByZXQ7XG4gICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgIHRoaXMuZGVsZXRlUHJlZml4ZWROYW1lKHByZWZpeGVkTmFtZSk7XG4gICAgICB0aHJvdyBlcnJvcjtcbiAgICB9XG4gIH1cblxuICBwcml2YXRlIGFzeW5jIGdldEltcGwobmFtZTogc3RyaW5nKTogUHJvbWlzZTxhbnk+IHtcbiAgICBjb25zdCBpdGVtU3RyaW5nID0gbG9jYWxTdG9yYWdlLmdldEl0ZW0obmFtZSk7XG4gICAgaWYgKCFpdGVtU3RyaW5nKSB7XG4gICAgICByZXR1cm4gbnVsbDtcbiAgICB9XG5cbiAgICBjb25zdCBpdGVtOiBJdGVtID0gSlNPTi5wYXJzZShpdGVtU3RyaW5nKTtcblxuICAgIGxldCBkYXRhOiBhbnk7XG5cbiAgICBpZiAoaXRlbS5leHBpcnkpIHtcbiAgICAgIGNvbnN0IGNvb2tpZUl0ZW1TdHJpbmcgPSB0aGlzLmNvb2tpZVNlcnZpY2UuZ2V0KG5hbWUpO1xuICAgICAgaWYgKCFjb29raWVJdGVtU3RyaW5nKSB7XG4gICAgICAgIC8vIFByb2JhYmx5IGV4cGlyZWQsIGJ1dCB3ZSB3b24ndCBtYWtlIGFueSBpbnRlcnByZXRhdGlvbnMgc2luY2UgaWYgd2Ugb25seSB1c2VkXG4gICAgICAgIC8vIGNvb2tpZXMgd2UgY2FuJ3QgdGVsbCBpZiBpdCdzIGV4cGlyZWQgb3IgZXhwbGljaXRseSByZW1vdmVkLiBTbyB3ZSBqdXN0IG1ha2VcbiAgICAgICAgLy8gdGhlIGJlaGF2aW91ciBoZXJlIGNvbnNpc3RlbnQgd2l0aCB0aGF0LlxuICAgICAgICBjb25zb2xlLmxvZygnTm8gY29va2llLicpO1xuICAgICAgICByZXR1cm4gbnVsbDtcbiAgICAgIH1cblxuICAgICAgY29uc3QgY29va2llSXRlbSA9IEpTT04ucGFyc2UoY29va2llSXRlbVN0cmluZyk7XG5cbiAgICAgIGNvbnN0IGtleSA9IGF3YWl0IEtGUy5hc0tleShjb29raWVJdGVtLmtleSk7XG5cbiAgICAgIGRhdGEgPSBhd2FpdCB0aGlzLmVuY3J5cHRpb25TZXJ2aWNlLmRlY3J5cHQoa2V5LCBpdGVtLmRhdGEpO1xuICAgIH0gZWxzZSB7XG4gICAgICBkYXRhID0gaXRlbS5kYXRhO1xuICAgIH1cblxuICAgIGlmIChpdGVtLnNlcnZlclNlc3Npb24pIHtcbiAgICAgIGRhdGEgPSBhd2FpdCB0aGlzLmVuY3J5cHRpb25TZXJ2aWNlLmRlY3J5cHQoXG4gICAgICAgIHRoaXMuc2VydmVyU2Vzc2lvbkVuY3J5cHRpb25LZXksXG4gICAgICAgIGRhdGFcbiAgICAgICk7XG4gICAgfVxuXG4gICAgcmV0dXJuIGRhdGE7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,214 @@
|
|
|
1
|
+
import { __awaiter, __rest } from "tslib";
|
|
2
|
+
import { Injectable } from '@angular/core';
|
|
3
|
+
import _ from 'lodash';
|
|
4
|
+
import { SharedContactCardService } from '../shared-contact-card/shared-contact-card.service';
|
|
5
|
+
import { LifeReadyAuthService } from '../auth/life-ready-auth.service';
|
|
6
|
+
import { TrustedPartyService } from '../trusted-party/trusted-party.service';
|
|
7
|
+
import { ProfileService } from './profile.service';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "../shared-contact-card/shared-contact-card.service";
|
|
10
|
+
import * as i2 from "../trusted-party/trusted-party.service";
|
|
11
|
+
import * as i3 from "./profile.service";
|
|
12
|
+
import * as i4 from "../auth/life-ready-auth.service";
|
|
13
|
+
var ContactFields;
|
|
14
|
+
(function (ContactFields) {
|
|
15
|
+
ContactFields["Name"] = "name";
|
|
16
|
+
ContactFields["Email"] = "email";
|
|
17
|
+
ContactFields["Image"] = "image";
|
|
18
|
+
ContactFields["Phone"] = "phone";
|
|
19
|
+
ContactFields["Address"] = "address";
|
|
20
|
+
})(ContactFields || (ContactFields = {}));
|
|
21
|
+
const FieldNames = [
|
|
22
|
+
ContactFields.Name,
|
|
23
|
+
ContactFields.Email,
|
|
24
|
+
ContactFields.Image,
|
|
25
|
+
ContactFields.Phone,
|
|
26
|
+
ContactFields.Address,
|
|
27
|
+
];
|
|
28
|
+
class FieldChange {
|
|
29
|
+
}
|
|
30
|
+
export class ProfileDetailsService {
|
|
31
|
+
constructor(sharedContactCardService, trustedPartyService, profileService, authService) {
|
|
32
|
+
this.sharedContactCardService = sharedContactCardService;
|
|
33
|
+
this.trustedPartyService = trustedPartyService;
|
|
34
|
+
this.profileService = profileService;
|
|
35
|
+
this.authService = authService;
|
|
36
|
+
}
|
|
37
|
+
updateDetails(fields) {
|
|
38
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
39
|
+
const user = yield this.authService.getUser();
|
|
40
|
+
yield this.profileService.updateDetails(user.contactCard.id, user.contactCard.keyId, fields);
|
|
41
|
+
yield this.synchronizeContactCards(fields, user.contactCard);
|
|
42
|
+
return yield this.authService.getUser(true);
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
synchronizeContactCards(newFields, oldFields) {
|
|
46
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
47
|
+
if (!oldFields)
|
|
48
|
+
return;
|
|
49
|
+
const changes = this.getChanges(newFields, oldFields);
|
|
50
|
+
if (changes.length === 0)
|
|
51
|
+
return;
|
|
52
|
+
const trustedParties = yield this.trustedPartyService.getTrustedParties();
|
|
53
|
+
if (trustedParties.length === 0)
|
|
54
|
+
return;
|
|
55
|
+
for (const details of trustedParties.map((x) => x.mySharedDetails)) {
|
|
56
|
+
yield this.synchronizeSharedContactCard(details, changes);
|
|
57
|
+
}
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
getChanges(newFields, oldFields) {
|
|
61
|
+
const changes = [];
|
|
62
|
+
for (const field of FieldNames) {
|
|
63
|
+
const oldField = oldFields[field];
|
|
64
|
+
if (oldField && oldField.values) {
|
|
65
|
+
for (const oldValue of oldField.values) {
|
|
66
|
+
const newValue = newFields[field].values.find((x) => x.id === oldValue.id);
|
|
67
|
+
if (!newValue) {
|
|
68
|
+
changes.push({
|
|
69
|
+
field,
|
|
70
|
+
id: oldValue.id,
|
|
71
|
+
label: oldValue.label,
|
|
72
|
+
oldValue: oldValue.value,
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
else if (!_.isEqual(newValue.value, oldValue.value)) {
|
|
76
|
+
changes.push({
|
|
77
|
+
field,
|
|
78
|
+
id: oldValue.id,
|
|
79
|
+
label: oldValue.label,
|
|
80
|
+
oldValue: oldValue.value,
|
|
81
|
+
newValue: newValue.value,
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
return changes;
|
|
88
|
+
}
|
|
89
|
+
synchronizeSharedContactCard(details, changes) {
|
|
90
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
91
|
+
let hasChanged = false;
|
|
92
|
+
for (const change of changes) {
|
|
93
|
+
switch (change.field) {
|
|
94
|
+
case ContactFields.Phone:
|
|
95
|
+
{
|
|
96
|
+
const value = details.phones &&
|
|
97
|
+
details.phones.find((x) => x.label === change.label);
|
|
98
|
+
if (value) {
|
|
99
|
+
hasChanged = true;
|
|
100
|
+
value.value = change.newValue;
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
break;
|
|
104
|
+
case ContactFields.Address:
|
|
105
|
+
{
|
|
106
|
+
const value = details.addresses &&
|
|
107
|
+
details.addresses.find((x) => x.label === change.label);
|
|
108
|
+
if (value) {
|
|
109
|
+
hasChanged = true;
|
|
110
|
+
value.value = change.newValue;
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
break;
|
|
114
|
+
default: {
|
|
115
|
+
const value = details[change.field];
|
|
116
|
+
if (_.isEqual(value, change.oldValue)) {
|
|
117
|
+
hasChanged = true;
|
|
118
|
+
details[change.field] = change.newValue;
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
if (hasChanged) {
|
|
124
|
+
const { id, ownedKeyId, sharedKeyId } = details, contactCard = __rest(details, ["id", "ownedKeyId", "sharedKeyId"]);
|
|
125
|
+
yield this.sharedContactCardService.updateMySharedContactCard(id, ownedKeyId, sharedKeyId, contactCard);
|
|
126
|
+
}
|
|
127
|
+
});
|
|
128
|
+
}
|
|
129
|
+
updateTrustedPartyDetails(details) {
|
|
130
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
131
|
+
const { id, ownedKeyId, sharedKeyId } = details, contactCard = __rest(details, ["id", "ownedKeyId", "sharedKeyId"]);
|
|
132
|
+
yield this.sharedContactCardService.updateMySharedContactCard(id, ownedKeyId, sharedKeyId, contactCard);
|
|
133
|
+
yield this.synchronizeSharedDetails(details);
|
|
134
|
+
});
|
|
135
|
+
}
|
|
136
|
+
synchronizeSharedDetails(details) {
|
|
137
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
138
|
+
let { contactCard } = yield this.authService.getUser();
|
|
139
|
+
let hasNewValues = false;
|
|
140
|
+
contactCard = Object.assign({}, contactCard);
|
|
141
|
+
if (details.name) {
|
|
142
|
+
const property = this.checkField(details.name, contactCard.name);
|
|
143
|
+
if (property) {
|
|
144
|
+
contactCard.name = property;
|
|
145
|
+
hasNewValues = true;
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
if (details.email) {
|
|
149
|
+
const property = this.checkField(details.email, contactCard.email);
|
|
150
|
+
if (property) {
|
|
151
|
+
contactCard.email = property;
|
|
152
|
+
hasNewValues = true;
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
if (details.image) {
|
|
156
|
+
const property = this.checkField(details.image, contactCard.image);
|
|
157
|
+
if (property) {
|
|
158
|
+
contactCard.image = property;
|
|
159
|
+
hasNewValues = true;
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
if (details.phones && details.phones.length) {
|
|
163
|
+
for (const phone of details.phones) {
|
|
164
|
+
const property = this.checkField(phone.value, contactCard.phone, phone.label);
|
|
165
|
+
if (property) {
|
|
166
|
+
contactCard.phone = property;
|
|
167
|
+
hasNewValues = true;
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
if (details.addresses && details.addresses.length) {
|
|
172
|
+
for (const address of details.addresses) {
|
|
173
|
+
const property = this.checkField(address.value, contactCard.address, address.label);
|
|
174
|
+
if (property) {
|
|
175
|
+
contactCard.address = property;
|
|
176
|
+
hasNewValues = true;
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
if (hasNewValues) {
|
|
181
|
+
yield this.profileService.updateDetails(contactCard.id, contactCard.keyId, contactCard);
|
|
182
|
+
}
|
|
183
|
+
});
|
|
184
|
+
}
|
|
185
|
+
checkField(field, property, label = null) {
|
|
186
|
+
property = property || { value: field, hasMultiple: false };
|
|
187
|
+
property.values = property.values || [];
|
|
188
|
+
if (property.values.length === 0 ||
|
|
189
|
+
property.values.every((x) => !_.isEqual(field, x.value))) {
|
|
190
|
+
property.values.push({
|
|
191
|
+
id: `${label}-${new Date().getTime()}`,
|
|
192
|
+
label,
|
|
193
|
+
value: field,
|
|
194
|
+
});
|
|
195
|
+
property.hasMultiple = property.values.length > 1;
|
|
196
|
+
property.value = property.value || field;
|
|
197
|
+
return property;
|
|
198
|
+
}
|
|
199
|
+
return null;
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
ProfileDetailsService.ɵprov = i0.ɵɵdefineInjectable({ factory: function ProfileDetailsService_Factory() { return new ProfileDetailsService(i0.ɵɵinject(i1.SharedContactCardService), i0.ɵɵinject(i2.TrustedPartyService), i0.ɵɵinject(i3.ProfileService), i0.ɵɵinject(i4.LifeReadyAuthService)); }, token: ProfileDetailsService, providedIn: "root" });
|
|
203
|
+
ProfileDetailsService.decorators = [
|
|
204
|
+
{ type: Injectable, args: [{
|
|
205
|
+
providedIn: 'root',
|
|
206
|
+
},] }
|
|
207
|
+
];
|
|
208
|
+
ProfileDetailsService.ctorParameters = () => [
|
|
209
|
+
{ type: SharedContactCardService },
|
|
210
|
+
{ type: TrustedPartyService },
|
|
211
|
+
{ type: ProfileService },
|
|
212
|
+
{ type: LifeReadyAuthService }
|
|
213
|
+
];
|
|
214
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZmlsZS1kZXRhaWxzLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiL29wdC9hdGxhc3NpYW4vcGlwZWxpbmVzL2FnZW50L2J1aWxkL3Byb2plY3RzL2NvcmUvc3JjLyIsInNvdXJjZXMiOlsibGliL3Byb2ZpbGUvcHJvZmlsZS1kZXRhaWxzLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxDQUFDLE1BQU0sUUFBUSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLG9EQUFvRCxDQUFDO0FBRTlGLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHdDQUF3QyxDQUFDO0FBRTdFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQzs7Ozs7O0FBT25ELElBQUssYUFNSjtBQU5ELFdBQUssYUFBYTtJQUNoQiw4QkFBYSxDQUFBO0lBQ2IsZ0NBQWUsQ0FBQTtJQUNmLGdDQUFlLENBQUE7SUFDZixnQ0FBZSxDQUFBO0lBQ2Ysb0NBQW1CLENBQUE7QUFDckIsQ0FBQyxFQU5JLGFBQWEsS0FBYixhQUFhLFFBTWpCO0FBRUQsTUFBTSxVQUFVLEdBQUc7SUFDakIsYUFBYSxDQUFDLElBQUk7SUFDbEIsYUFBYSxDQUFDLEtBQUs7SUFDbkIsYUFBYSxDQUFDLEtBQUs7SUFDbkIsYUFBYSxDQUFDLEtBQUs7SUFDbkIsYUFBYSxDQUFDLE9BQU87Q0FDdEIsQ0FBQztBQUVGLE1BQU0sV0FBVztDQU1oQjtBQUtELE1BQU0sT0FBTyxxQkFBcUI7SUFDaEMsWUFDVSx3QkFBa0QsRUFDbEQsbUJBQXdDLEVBQ3hDLGNBQThCLEVBQzlCLFdBQWlDO1FBSGpDLDZCQUF3QixHQUF4Qix3QkFBd0IsQ0FBMEI7UUFDbEQsd0JBQW1CLEdBQW5CLG1CQUFtQixDQUFxQjtR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S0FBSyxHQUFHLFFBQVEsQ0FBQyxLQUFLLElBQUksS0FBSyxDQUFDO1lBQ3pDLE9BQU8sUUFBUSxDQUFDO1NBQ2pCO1FBQ0QsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDOzs7O1lBOU9GLFVBQVUsU0FBQztnQkFDVixVQUFVLEVBQUUsTUFBTTthQUNuQjs7O1lBdENRLHdCQUF3QjtZQUd4QixtQkFBbUI7WUFFbkIsY0FBYztZQUhkLG9CQUFvQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCBfIGZyb20gJ2xvZGFzaCc7XG5pbXBvcnQgeyBTaGFyZWRDb250YWN0Q2FyZFNlcnZpY2UgfSBmcm9tICcuLi9zaGFyZWQtY29udGFjdC1jYXJkL3NoYXJlZC1jb250YWN0LWNhcmQuc2VydmljZSc7XG5pbXBvcnQgeyBDdXJyZW50VXNlciB9IGZyb20gJy4uL2F1dGgvYXV0aC50eXBlcyc7XG5pbXBvcnQgeyBMaWZlUmVhZHlBdXRoU2VydmljZSB9IGZyb20gJy4uL2F1dGgvbGlmZS1yZWFkeS1hdXRoLnNlcnZpY2UnO1xuaW1wb3J0IHsgVHJ1c3RlZFBhcnR5U2VydmljZSB9IGZyb20gJy4uL3RydXN0ZWQtcGFydHkvdHJ1c3RlZC1wYXJ0eS5zZXJ2aWNlJztcbmltcG9ydCB7IFNoYXJlZFRydXN0ZWRQYXJ0eURldGFpbHMgfSBmcm9tICcuLi90cnVzdGVkLXBhcnR5L3RydXN0ZWQtcGFydHkudHlwZXMnO1xuaW1wb3J0IHsgUHJvZmlsZVNlcnZpY2UgfSBmcm9tICcuL3Byb2ZpbGUuc2VydmljZSc7XG5pbXBvcnQge1xuICBNYWluQ29udGFjdENhcmRGaWVsZHMsXG4gIE1haW5Db250YWN0Q2FyZFByb3BlcnR5LFxuICBUcnVzdGVkUGFydHlEZXRhaWxzLFxufSBmcm9tICcuL3Byb2ZpbGUudHlwZXMnO1xuXG5lbnVtIENvbnRhY3RGaWVsZHMge1xuICBOYW1lID0gJ25hbWUnLFxuICBFbWFpbCA9ICdlbWFpbCcsXG4gIEltYWdlID0gJ2ltYWdlJyxcbiAgUGhvbmUgPSAncGhvbmUnLFxuICBBZGRyZXNzID0gJ2FkZHJlc3MnLFxufVxuXG5jb25zdCBGaWVsZE5hbWVzID0gW1xuICBDb250YWN0RmllbGRzLk5hbWUsXG4gIENvbnRhY3RGaWVsZHMuRW1haWwsXG4gIENvbnRhY3RGaWVsZHMuSW1hZ2UsXG4gIENvbnRhY3RGaWVsZHMuUGhvbmUsXG4gIENvbnRhY3RGaWVsZHMuQWRkcmVzcyxcbl07XG5cbmNsYXNzIEZpZWxkQ2hhbmdlIHtcbiAgZmllbGQ6IHN0cmluZztcbiAgaWQ6IHN0cmluZztcbiAgbGFiZWw6IHN0cmluZztcbiAgb2xkVmFsdWU/OiBhbnk7XG4gIG5ld1ZhbHVlPzogYW55O1xufVxuXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290Jyxcbn0pXG5leHBvcnQgY2xhc3MgUHJvZmlsZURldGFpbHNTZXJ2aWNlIHtcbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSBzaGFyZWRDb250YWN0Q2FyZFNlcnZpY2U6IFNoYXJlZENvbnRhY3RDYXJkU2VydmljZSxcbiAgICBwcml2YXRlIHRydXN0ZWRQYXJ0eVNlcnZpY2U6IFRydXN0ZWRQYXJ0eVNlcnZpY2UsXG4gICAgcHJpdmF0ZSBwcm9maWxlU2VydmljZTogUHJvZmlsZVNlcnZpY2UsXG4gICAgcHJpdmF0ZSBhdXRoU2VydmljZTogTGlmZVJlYWR5QXV0aFNlcnZpY2VcbiAgKSB7fVxuXG4gIHB1YmxpYyBhc3luYyB1cGRhdGVEZXRhaWxzKFxuICAgIGZpZWxkczogTWFpbkNvbnRhY3RDYXJkRmllbGRzXG4gICk6IFByb21pc2U8Q3VycmVudFVzZXI+IHtcbiAgICBjb25zdCB1c2VyID0gYXdhaXQgdGhpcy5hdXRoU2VydmljZS5nZXRVc2VyKCk7XG4gICAgYXdhaXQgdGhpcy5wcm9maWxlU2VydmljZS51cGRhdGVEZXRhaWxzKFxuICAgICAgdXNlci5jb250YWN0Q2FyZC5pZCxcbiAgICAgIHVzZXIuY29udGFjdENhcmQua2V5SWQsXG4gICAgICBmaWVsZHNcbiAgICApO1xuICAgIGF3YWl0IHRoaXMuc3luY2hyb25pemVDb250YWN0Q2FyZHMoZmllbGRzLCB1c2VyLmNvbnRhY3RDYXJkKTtcbiAgICByZXR1cm4gYXdhaXQgdGhpcy5hdXRoU2VydmljZS5nZXRVc2VyKHRydWUpO1xuICB9XG5cbiAgcHJpdmF0ZSBhc3luYyBzeW5jaHJvbml6ZUNvbnRhY3RDYXJkcyhcbiAgICBuZXdGaWVsZHM6IE1haW5Db250YWN0Q2FyZEZpZWxkcyxcbiAgICBvbGRGaWVsZHM6IE1haW5Db250YWN0Q2FyZEZpZWxkc1xuICApOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBpZiAoIW9sZEZpZWxkcykgcmV0dXJuO1xuXG4gICAgY29uc3QgY2hhbmdlcyA9IHRoaXMuZ2V0Q2hhbmdlcyhuZXdGaWVsZHMsIG9sZEZpZWxkcyk7XG5cbiAgICBpZiAoY2hhbmdlcy5sZW5ndGggPT09IDApIHJldHVybjtcblxuICAgIGNvbnN0IHRydXN0ZWRQYXJ0aWVzID0gYXdhaXQgdGhpcy50cnVzdGVkUGFydHlTZXJ2aWNlLmdldFRydXN0ZWRQYXJ0aWVzKCk7XG5cbiAgICBpZiAodHJ1c3RlZFBhcnRpZXMubGVuZ3RoID09PSAwKSByZXR1cm47XG5cbiAgICBmb3IgKGNvbnN0IGRldGFpbHMgb2YgdHJ1c3RlZFBhcnRpZXMubWFwKCh4KSA9PiB4Lm15U2hhcmVkRGV0YWlscykpIHtcbiAgICAgIGF3YWl0IHRoaXMuc3luY2hyb25pemVTaGFyZWRDb250YWN0Q2FyZChkZXRhaWxzLCBjaGFuZ2VzKTtcbiAgICB9XG4gIH1cblxuICBwcml2YXRlIGdldENoYW5nZXMoXG4gICAgbmV3RmllbGRzOiBNYWluQ29udGFjdENhcmRGaWVsZHMsXG4gICAgb2xkRmllbGRzOiBNYWluQ29udGFjdENhcmRGaWVsZHNcbiAgKTogRmllbGRDaGFuZ2VbXSB7XG4gICAgY29uc3QgY2hhbmdlczogRmllbGRDaGFuZ2VbXSA9IFtdO1xuXG4gICAgZm9yIChjb25zdCBmaWVsZCBvZiBGaWVsZE5hbWVzKSB7XG4gICAgICBjb25zdCBvbGRGaWVsZCA9IG9sZEZpZWxkc1tmaWVsZF07XG4gICAgICBpZiAob2xkRmllbGQgJiYgb2xkRmllbGQudmFsdWVzKSB7XG4gICAgICAgIGZvciAoY29uc3Qgb2xkVmFsdWUgb2Ygb2xkRmllbGQudmFsdWVzKSB7XG4gICAgICAgICAgY29uc3QgbmV3VmFsdWUgPSAobmV3RmllbGRzW2ZpZWxkXS52YWx1ZXMgYXMgYW55W10pLmZpbmQoXG4gICAgICAgICAgICAoeCkgPT4geC5pZCA9PT0gb2xkVmFsdWUuaWRcbiAgICAgICAgICApO1xuXG4gICAgICAgICAgaWYgKCFuZXdWYWx1ZSkge1xuICAgICAgICAgICAgY2hhbmdlcy5wdXNoKHtcbiAgICAgICAgICAgICAgZmllbGQsXG4gICAgICAgICAgICAgIGlkOiBvbGRWYWx1ZS5pZCxcbiAgICAgICAgICAgICAgbGFiZWw6IG9sZFZhbHVlLmxhYmVsLFxuICAgICAgICAgICAgICBvbGRWYWx1ZTogb2xkVmFsdWUudmFsdWUsXG4gICAgICAgICAgICB9KTtcbiAgICAgICAgICB9IGVsc2UgaWYgKCFfLmlzRXF1YWwobmV3VmFsdWUudmFsdWUsIG9sZFZhbHVlLnZhbHVlKSkge1xuICAgICAgICAgICAgY2hhbmdlcy5wdXNoKHtcbiAgICAgICAgICAgICAgZmllbGQsXG4gICAgICAgICAgICAgIGlkOiBvbGRWYWx1ZS5pZCxcbiAgICAgICAgICAgICAgbGFiZWw6IG9sZFZhbHVlLmxhYmVsLFxuICAgICAgICAgICAgICBvbGRWYWx1ZTogb2xkVmFsdWUudmFsdWUsXG4gICAgICAgICAgICAgIG5ld1ZhbHVlOiBuZXdWYWx1ZS52YWx1ZSxcbiAgICAgICAgICAgIH0pO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cbiAgICByZXR1cm4gY2hhbmdlcztcbiAgfVxuXG4gIHByaXZhdGUgYXN5bmMgc3luY2hyb25pemVTaGFyZWRDb250YWN0Q2FyZChcbiAgICBkZXRhaWxzOiBTaGFyZWRUcnVzdGVkUGFydHlEZXRhaWxzLFxuICAgIGNoYW5nZXM6IEZpZWxkQ2hhbmdlW11cbiAgKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgbGV0IGhhc0NoYW5nZWQgPSBmYWxzZTtcbiAgICBmb3IgKGNvbnN0IGNoYW5nZSBvZiBjaGFuZ2VzKSB7XG4gICAgICBzd2l0Y2ggKGNoYW5nZS5maWVsZCkge1xuICAgICAgICBjYXNlIENvbnRhY3RGaWVsZHMuUGhvbmU6XG4gICAgICAgICAge1xuICAgICAgICAgICAgY29uc3QgdmFsdWUgPVxuICAgICAgICAgICAgICBkZXRhaWxzLnBob25lcyAmJlxuICAgICAgICAgICAgICBkZXRhaWxzLnBob25lcy5maW5kKCh4KSA9PiB4LmxhYmVsID09PSBjaGFuZ2UubGFiZWwpO1xuXG4gICAgICAgICAgICBpZiAodmFsdWUpIHtcbiAgICAgICAgICAgICAgaGFzQ2hhbmdlZCA9IHRydWU7XG4gICAgICAgICAgICAgIHZhbHVlLnZhbHVlID0gY2hhbmdlLm5ld1ZhbHVlO1xuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cbiAgICAgICAgICBicmVhaztcbiAgICAgICAgY2FzZSBDb250YWN0RmllbGRzLkFkZHJlc3M6XG4gICAgICAgICAge1xuICAgICAgICAgICAgY29uc3QgdmFsdWUgPVxuICAgICAgICAgICAgICBkZXRhaWxzLmFkZHJlc3NlcyAmJlxuICAgICAgICAgICAgICBkZXRhaWxzLmFkZHJlc3Nlcy5maW5kKCh4KSA9PiB4LmxhYmVsID09PSBjaGFuZ2UubGFiZWwpO1xuXG4gICAgICAgICAgICBpZiAodmFsdWUpIHtcbiAgICAgICAgICAgICAgaGFzQ2hhbmdlZCA9IHRydWU7XG4gICAgICAgICAgICAgIHZhbHVlLnZhbHVlID0gY2hhbmdlLm5ld1ZhbHVlO1xuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cbiAgICAgICAgICBicmVhaztcbiAgICAgICAgZGVmYXVsdDoge1xuICAgICAgICAgIGNvbnN0IHZhbHVlID0gZGV0YWlsc1tjaGFuZ2UuZmllbGRdO1xuXG4gICAgICAgICAgaWYgKF8uaXNFcXVhbCh2YWx1ZSwgY2hhbmdlLm9sZFZhbHVlKSkge1xuICAgICAgICAgICAgaGFzQ2hhbmdlZCA9IHRydWU7XG4gICAgICAgICAgICBkZXRhaWxzW2NoYW5nZS5maWVsZF0gPSBjaGFuZ2UubmV3VmFsdWU7XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuICAgIGlmIChoYXNDaGFuZ2VkKSB7XG4gICAgICBjb25zdCB7IGlkLCBvd25lZEtleUlkLCBzaGFyZWRLZXlJZCwgLi4uY29udGFjdENhcmQgfSA9IGRldGFpbHM7XG5cbiAgICAgIGF3YWl0IHRoaXMuc2hhcmVkQ29udGFjdENhcmRTZXJ2aWNlLnVwZGF0ZU15U2hhcmVkQ29udGFjdENhcmQoXG4gICAgICAgIGlkLFxuICAgICAgICBvd25lZEtleUlkLFxuICAgICAgICBzaGFyZWRLZXlJZCxcbiAgICAgICAgY29udGFjdENhcmRcbiAgICAgICk7XG4gICAgfVxuICB9XG5cbiAgcHVibGljIGFzeW5jIHVwZGF0ZVRydXN0ZWRQYXJ0eURldGFpbHMoZGV0YWlsczogU2hhcmVkVHJ1c3RlZFBhcnR5RGV0YWlscykge1xuICAgIGNvbnN0IHsgaWQsIG93bmVkS2V5SWQsIHNoYXJlZEtleUlkLCAuLi5jb250YWN0Q2FyZCB9ID0gZGV0YWlscztcblxuICAgIGF3YWl0IHRoaXMuc2hhcmVkQ29udGFjdENhcmRTZXJ2aWNlLnVwZGF0ZU15U2hhcmVkQ29udGFjdENhcmQoXG4gICAgICBpZCxcbiAgICAgIG93bmVkS2V5SWQsXG4gICAgICBzaGFyZWRLZXlJZCxcbiAgICAgIGNvbnRhY3RDYXJkXG4gICAgKTtcblxuICAgIGF3YWl0IHRoaXMuc3luY2hyb25pemVTaGFyZWREZXRhaWxzKGRldGFpbHMpO1xuICB9XG5cbiAgcHVibGljIGFzeW5jIHN5bmNocm9uaXplU2hhcmVkRGV0YWlscyhkZXRhaWxzOiBUcnVzdGVkUGFydHlEZXRhaWxzKSB7XG4gICAgbGV0IHsgY29udGFjdENhcmQgfSA9IGF3YWl0IHRoaXMuYXV0aFNlcnZpY2UuZ2V0VXNlcigpO1xuICAgIGxldCBoYXNOZXdWYWx1ZXMgPSBmYWxzZTtcbiAgICBjb250YWN0Q2FyZCA9IHsgLi4uY29udGFjdENhcmQgfTtcblxuICAgIGlmIChkZXRhaWxzLm5hbWUpIHtcbiAgICAgIGNvbnN0IHByb3BlcnR5ID0gdGhpcy5jaGVja0ZpZWxkKGRldGFpbHMubmFtZSwgY29udGFjdENhcmQubmFtZSk7XG5cbiAgICAgIGlmIChwcm9wZXJ0eSkge1xuICAgICAgICBjb250YWN0Q2FyZC5uYW1lID0gcHJvcGVydHk7XG4gICAgICAgIGhhc05ld1ZhbHVlcyA9IHRydWU7XG4gICAgICB9XG4gICAgfVxuXG4gICAgaWYgKGRldGFpbHMuZW1haWwpIHtcbiAgICAgIGNvbnN0IHByb3BlcnR5ID0gdGhpcy5jaGVja0ZpZWxkKGRldGFpbHMuZW1haWwsIGNvbnRhY3RDYXJkLmVtYWlsKTtcblxuICAgICAgaWYgKHByb3BlcnR5KSB7XG4gICAgICAgIGNvbnRhY3RDYXJkLmVtYWlsID0gcHJvcGVydHk7XG4gICAgICAgIGhhc05ld1ZhbHVlcyA9IHRydWU7XG4gICAgICB9XG4gICAgfVxuXG4gICAgaWYgKGRldGFpbHMuaW1hZ2UpIHtcbiAgICAgIGNvbnN0IHByb3BlcnR5ID0gdGhpcy5jaGVja0ZpZWxkKGRldGFpbHMuaW1hZ2UsIGNvbnRhY3RDYXJkLmltYWdlKTtcblxuICAgICAgaWYgKHByb3BlcnR5KSB7XG4gICAgICAgIGNvbnRhY3RDYXJkLmltYWdlID0gcHJvcGVydHk7XG4gICAgICAgIGhhc05ld1ZhbHVlcyA9IHRydWU7XG4gICAgICB9XG4gICAgfVxuXG4gICAgaWYgKGRldGFpbHMucGhvbmVzICYmIGRldGFpbHMucGhvbmVzLmxlbmd0aCkge1xuICAgICAgZm9yIChjb25zdCBwaG9uZSBvZiBkZXRhaWxzLnBob25lcykge1xuICAgICAgICBjb25zdCBwcm9wZXJ0eSA9IHRoaXMuY2hlY2tGaWVsZChcbiAgICAgICAgICBwaG9uZS52YWx1ZSxcbiAgICAgICAgICBjb250YWN0Q2FyZC5waG9uZSxcbiAgICAgICAgICBwaG9uZS5sYWJlbFxuICAgICAgICApO1xuXG4gICAgICAgIGlmIChwcm9wZXJ0eSkge1xuICAgICAgICAgIGNvbnRhY3RDYXJkLnBob25lID0gcHJvcGVydHk7XG4gICAgICAgICAgaGFzTmV3VmFsdWVzID0gdHJ1ZTtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cblxuICAgIGlmIChkZXRhaWxzLmFkZHJlc3NlcyAmJiBkZXRhaWxzLmFkZHJlc3Nlcy5sZW5ndGgpIHtcbiAgICAgIGZvciAoY29uc3QgYWRkcmVzcyBvZiBkZXRhaWxzLmFkZHJlc3Nlcykge1xuICAgICAgICBjb25zdCBwcm9wZXJ0eSA9IHRoaXMuY2hlY2tGaWVsZChcbiAgICAgICAgICBhZGRyZXNzLnZhbHVlLFxuICAgICAgICAgIGNvbnRhY3RDYXJkLmFkZHJlc3MsXG4gICAgICAgICAgYWRkcmVzcy5sYWJlbFxuICAgICAgICApO1xuXG4gICAgICAgIGlmIChwcm9wZXJ0eSkge1xuICAgICAgICAgIGNvbnRhY3RDYXJkLmFkZHJlc3MgPSBwcm9wZXJ0eTtcbiAgICAgICAgICBoYXNOZXdWYWx1ZXMgPSB0cnVlO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuXG4gICAgaWYgKGhhc05ld1ZhbHVlcykge1xuICAgICAgYXdhaXQgdGhpcy5wcm9maWxlU2VydmljZS51cGRhdGVEZXRhaWxzKFxuICAgICAgICBjb250YWN0Q2FyZC5pZCxcbiAgICAgICAgY29udGFjdENhcmQua2V5SWQsXG4gICAgICAgIGNvbnRhY3RDYXJkXG4gICAgICApO1xuICAgIH1cbiAgfVxuXG4gIHByaXZhdGUgY2hlY2tGaWVsZDxUPihcbiAgICBmaWVsZDogVCxcbiAgICBwcm9wZXJ0eTogTWFpbkNvbnRhY3RDYXJkUHJvcGVydHk8VD4sXG4gICAgbGFiZWw6IHN0cmluZyA9IG51bGxcbiAgKSB7XG4gICAgcHJvcGVydHkgPSBwcm9wZXJ0eSB8fCB7IHZhbHVlOiBmaWVsZCwgaGFzTXVsdGlwbGU6IGZhbHNlIH07XG4gICAgcHJvcGVydHkudmFsdWVzID0gcHJvcGVydHkudmFsdWVzIHx8IFtdO1xuXG4gICAgaWYgKFxuICAgICAgcHJvcGVydHkudmFsdWVzLmxlbmd0aCA9PT0gMCB8fFxuICAgICAgcHJvcGVydHkudmFsdWVzLmV2ZXJ5KCh4KSA9PiAhXy5pc0VxdWFsKGZpZWxkLCB4LnZhbHVlKSlcbiAgICApIHtcbiAgICAgIHByb3BlcnR5LnZhbHVlcy5wdXNoKHtcbiAgICAgICAgaWQ6IGAke2xhYmVsfS0ke25ldyBEYXRlKCkuZ2V0VGltZSgpfWAsXG4gICAgICAgIGxhYmVsLFxuICAgICAgICB2YWx1ZTogZmllbGQsXG4gICAgICB9KTtcbiAgICAgIHByb3BlcnR5Lmhhc011bHRpcGxlID0gcHJvcGVydHkudmFsdWVzLmxlbmd0aCA+IDE7XG4gICAgICBwcm9wZXJ0eS52YWx1ZSA9IHByb3BlcnR5LnZhbHVlIHx8IGZpZWxkO1xuICAgICAgcmV0dXJuIHByb3BlcnR5O1xuICAgIH1cbiAgICByZXR1cm4gbnVsbDtcbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
import gql from 'graphql-tag';
|
|
2
|
+
import { KeyGraphFragment } from '../_common/queries.gql';
|
|
3
|
+
export const CurrentUserQuery = gql `
|
|
4
|
+
query {
|
|
5
|
+
currentUser {
|
|
6
|
+
id
|
|
7
|
+
username
|
|
8
|
+
currentUserKey {
|
|
9
|
+
passKey {
|
|
10
|
+
id
|
|
11
|
+
passKeyParams
|
|
12
|
+
passIdpParams
|
|
13
|
+
wrappedPassIdpVerifierPrk
|
|
14
|
+
created
|
|
15
|
+
}
|
|
16
|
+
masterKey {
|
|
17
|
+
id
|
|
18
|
+
}
|
|
19
|
+
rootKey {
|
|
20
|
+
id
|
|
21
|
+
}
|
|
22
|
+
pxk {
|
|
23
|
+
id
|
|
24
|
+
}
|
|
25
|
+
sigPxk {
|
|
26
|
+
id
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
userDelete {
|
|
30
|
+
id
|
|
31
|
+
created
|
|
32
|
+
state
|
|
33
|
+
}
|
|
34
|
+
features {
|
|
35
|
+
myVault
|
|
36
|
+
tpVault
|
|
37
|
+
shareVault
|
|
38
|
+
}
|
|
39
|
+
sessionEncryptionKey
|
|
40
|
+
}
|
|
41
|
+
userPlans {
|
|
42
|
+
id
|
|
43
|
+
stripe {
|
|
44
|
+
subscriptionId
|
|
45
|
+
}
|
|
46
|
+
plan {
|
|
47
|
+
name
|
|
48
|
+
data
|
|
49
|
+
state
|
|
50
|
+
}
|
|
51
|
+
periodEnd
|
|
52
|
+
}
|
|
53
|
+
contactCards(orderBy: "created") {
|
|
54
|
+
edges {
|
|
55
|
+
node {
|
|
56
|
+
id
|
|
57
|
+
key {
|
|
58
|
+
id
|
|
59
|
+
}
|
|
60
|
+
cipherData
|
|
61
|
+
plainData
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
keyGraph {
|
|
66
|
+
...KeyGraphFragment
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
${KeyGraphFragment}
|
|
70
|
+
`;
|
|
71
|
+
export const CreateContactCardMutation = gql `
|
|
72
|
+
mutation CreateContactCardMutation($input: CreateContactCardInput!) {
|
|
73
|
+
createContactCard(input: $input) {
|
|
74
|
+
contactCard {
|
|
75
|
+
id
|
|
76
|
+
key {
|
|
77
|
+
id
|
|
78
|
+
}
|
|
79
|
+
cipherData
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
`;
|
|
84
|
+
export const UpdateContactCardMutation = gql `
|
|
85
|
+
mutation UpdateContactCardMutation($input: UpdateContactCardInput!) {
|
|
86
|
+
updateContactCard(input: $input) {
|
|
87
|
+
contactCard {
|
|
88
|
+
id
|
|
89
|
+
key {
|
|
90
|
+
id
|
|
91
|
+
}
|
|
92
|
+
cipherData
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
`;
|
|
97
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZmlsZS5ncWwuanMiLCJzb3VyY2VSb290IjoiL29wdC9hdGxhc3NpYW4vcGlwZWxpbmVzL2FnZW50L2J1aWxkL3Byb2plY3RzL2NvcmUvc3JjLyIsInNvdXJjZXMiOlsibGliL3Byb2ZpbGUvcHJvZmlsZS5ncWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxHQUFHLE1BQU0sYUFBYSxDQUFDO0FBQzlCLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBVzFELE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHLEdBQUcsQ0FBQTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0lBa0UvQixnQkFBZ0I7Q0FDbkIsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLHlCQUF5QixHQUFHLEdBQUcsQ0FBQTs7Ozs7Ozs7Ozs7O0NBWTNDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSx5QkFBeUIsR0FBRyxHQUFHLENBQUE7Ozs7Ozs7Ozs7OztDQVkzQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGdxbCBmcm9tICdncmFwaHFsLXRhZyc7XG5pbXBvcnQgeyBLZXlHcmFwaEZyYWdtZW50IH0gZnJvbSAnLi4vX2NvbW1vbi9xdWVyaWVzLmdxbCc7XG5pbXBvcnQgeyBIYXNLZXlHcmFwaCB9IGZyb20gJy4uL2tleS9rZXkudHlwZXMnO1xuaW1wb3J0IHsgSGFzRWRnZXMgfSBmcm9tICcuLy4uL19jb21tb24vdHlwZXMnO1xuaW1wb3J0IHsgQXBpQ29udGFjdENhcmQsIEFwaUN1cnJlbnRVc2VyIH0gZnJvbSAnLi9wcm9maWxlLnR5cGVzJztcblxuZXhwb3J0IGludGVyZmFjZSBDdXJyZW50VXNlclF1ZXJ5VHlwZSBleHRlbmRzIEhhc0tleUdyYXBoIHtcbiAgY3VycmVudFVzZXI6IEFwaUN1cnJlbnRVc2VyO1xuICBjb250YWN0Q2FyZHM6IEhhc0VkZ2VzPEFwaUNvbnRhY3RDYXJkPjtcbiAgdXNlclBsYW5zOiBhbnlbXTtcbn1cblxuZXhwb3J0IGNvbnN0IEN1cnJlbnRVc2VyUXVlcnkgPSBncWxgXG4gIHF1ZXJ5IHtcbiAgICBjdXJyZW50VXNlciB7XG4gICAgICBpZFxuICAgICAgdXNlcm5hbWVcbiAgICAgIGN1cnJlbnRVc2VyS2V5IHtcbiAgICAgICAgcGFzc0tleSB7XG4gICAgICAgICAgaWRcbiAgICAgICAgICBwYXNzS2V5UGFyYW1zXG4gICAgICAgICAgcGFzc0lkcFBhcmFtc1xuICAgICAgICAgIHdyYXBwZWRQYXNzSWRwVmVyaWZpZXJQcmtcbiAgICAgICAgICBjcmVhdGVkXG4gICAgICAgIH1cbiAgICAgICAgbWFzdGVyS2V5IHtcbiAgICAgICAgICBpZFxuICAgICAgICB9XG4gICAgICAgIHJvb3RLZXkge1xuICAgICAgICAgIGlkXG4gICAgICAgIH1cbiAgICAgICAgcHhrIHtcbiAgICAgICAgICBpZFxuICAgICAgICB9XG4gICAgICAgIHNpZ1B4ayB7XG4gICAgICAgICAgaWRcbiAgICAgICAgfVxuICAgICAgfVxuICAgICAgdXNlckRlbGV0ZSB7XG4gICAgICAgIGlkXG4gICAgICAgIGNyZWF0ZWRcbiAgICAgICAgc3RhdGVcbiAgICAgIH1cbiAgICAgIGZlYXR1cmVzIHtcbiAgICAgICAgbXlWYXVsdFxuICAgICAgICB0cFZhdWx0XG4gICAgICAgIHNoYXJlVmF1bHRcbiAgICAgIH1cbiAgICAgIHNlc3Npb25FbmNyeXB0aW9uS2V5XG4gICAgfVxuICAgIHVzZXJQbGFucyB7XG4gICAgICBpZFxuICAgICAgc3RyaXBlIHtcbiAgICAgICAgc3Vic2NyaXB0aW9uSWRcbiAgICAgIH1cbiAgICAgIHBsYW4ge1xuICAgICAgICBuYW1lXG4gICAgICAgIGRhdGFcbiAgICAgICAgc3RhdGVcbiAgICAgIH1cbiAgICAgIHBlcmlvZEVuZFxuICAgIH1cbiAgICBjb250YWN0Q2FyZHMob3JkZXJCeTogXCJjcmVhdGVkXCIpIHtcbiAgICAgIGVkZ2VzIHtcbiAgICAgICAgbm9kZSB7XG4gICAgICAgICAgaWRcbiAgICAgICAgICBrZXkge1xuICAgICAgICAgICAgaWRcbiAgICAgICAgICB9XG4gICAgICAgICAgY2lwaGVyRGF0YVxuICAgICAgICAgIHBsYWluRGF0YVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuICAgIGtleUdyYXBoIHtcbiAgICAgIC4uLktleUdyYXBoRnJhZ21lbnRcbiAgICB9XG4gIH1cbiAgJHtLZXlHcmFwaEZyYWdtZW50fVxuYDtcblxuZXhwb3J0IGNvbnN0IENyZWF0ZUNvbnRhY3RDYXJkTXV0YXRpb24gPSBncWxgXG4gIG11dGF0aW9uIENyZWF0ZUNvbnRhY3RDYXJkTXV0YXRpb24oJGlucHV0OiBDcmVhdGVDb250YWN0Q2FyZElucHV0ISkge1xuICAgIGNyZWF0ZUNvbnRhY3RDYXJkKGlucHV0OiAkaW5wdXQpIHtcbiAgICAgIGNvbnRhY3RDYXJkIHtcbiAgICAgICAgaWRcbiAgICAgICAga2V5IHtcbiAgICAgICAgICBpZFxuICAgICAgICB9XG4gICAgICAgIGNpcGhlckRhdGFcbiAgICAgIH1cbiAgICB9XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBVcGRhdGVDb250YWN0Q2FyZE11dGF0aW9uID0gZ3FsYFxuICBtdXRhdGlvbiBVcGRhdGVDb250YWN0Q2FyZE11dGF0aW9uKCRpbnB1dDogVXBkYXRlQ29udGFjdENhcmRJbnB1dCEpIHtcbiAgICB1cGRhdGVDb250YWN0Q2FyZChpbnB1dDogJGlucHV0KSB7XG4gICAgICBjb250YWN0Q2FyZCB7XG4gICAgICAgIGlkXG4gICAgICAgIGtleSB7XG4gICAgICAgICAgaWRcbiAgICAgICAgfVxuICAgICAgICBjaXBoZXJEYXRhXG4gICAgICB9XG4gICAgfVxuICB9XG5gO1xuIl19
|