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